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本 书 由 浅 入 深 ， 全 面 、 系 统 地 介绍 了 PHP 开发 技术 ， 并 提供 了 大 量 实例 ， 供 读者 实战 演练 。 另 外 ， 笔 者 专门 为 本 
书 录制 了 相应 的 配套 教学 视频 , 以 帮助 读者 更 好 地 学 习 本 书 内容 。 这 些 视频 和 书 中 的 实例 源 代码 一 起 收录 于 配 书 光 盘 中 。 

本 书 共 分 4 篇 。 第 1 篇 是 PHP 准备 篇 , 介绍 了 PHP 的 优势 、 开 发 环境 及 安装 ; 第 2 篇 是 PHP 基础 篇 介绍 了 PHP 
中 的 常量 与 变量 、 运 算 符 与 表达 式 、 流 程控 制 以 及 函数 ; 第 3 篇 是 进 阶 篇 ， 介 绍 了 PHP 的 数据 处 理 、 文 件 应 用 、 获 取 
主机 信息 、 图 像 处 理 、Session 与 Cookie、 正 则 表达 式 、 面 向 对 象 编程 以 及 MySQL 数据 库 ， 第 4 篇 是 应 用 篇 ， 介 绍 了 
Hi PHP 实现 人 机 交互 、 计 数 器 程序 、 网 上 投票 程序 、 文 本 留言 板 程序 、PHP 博客 程序 、 简 单 的 BBS 系统 以 及 网 上 商城 
全 站 系统 ， 以 提高 读者 实战 水 平 。 

本 书 涉及 面 广 ， 从 基础 知识 到 高 级 技术 ， 再 到 项 目 开 发 ， 几 乎 涉及 PHP 开发 的 所 有 重要 知识 。 本 书 适合 所 有 想 全 
面 学 习 PHP 开发 技术 的 人 员 阅 读 ， 也 适合 使 用 PHP 进行 开发 的 工程 技术 人 员 使 用 。 对 于 经 常 使 用 PHP 做 开发 的 人 员 ， 
更 是 一 本 不 可 多 得 的 案头 必 备 参考 书 。 


本 书 封 面 贴 有 清华 大 学 出 版 社 防伪 标签 ， 无 标签 者 不 得 销售 。 
版 权 所 有 ， 侵 权 必 究 。 侵 权 举 报 电话 : 010-62782989 13701121933 


图 书 在 版 编目 CIP) 数据 


PHP 网 络 编程 技术 详解 / 葛 丽 车 编著 . 一 北京 : 清华 大 学 出 版 社 ，2014 
(网 站 开发 非常 之 旅 ) 


ISBN 978-7-302-34318-9 
LOP- IL @ 葛 … II OPHP 语言 -程序 设计 IV. OTP312 
中 国 版 本 图 书馆 CIP 数据 核 字 (2013) 第 255162 号 


责任 编辑 ， 朱 英 彪 

封面 设计 : 刘 超 

版 式 设计 : 文 森 时 代 

责任 校对 : 赵 丽 杰 

责任 印 制 : 

出 版 发 行 : 清华 大 学 出 版 社 
网 Jib: http://www.tup.com.cn, http://www.wqbook.com 
地 db: 北京 清华 大 学 学 研 大 厦 A 座 邮 ” 编 : 100084 
社 总 机 : 010-62770175 邮 购 : 010-62786544 
投稿 与 读者 服务 ; 010-62776969，c-service@tup.tsinghua.edu.cn 

量 反馈 : 010-62772015, zhiliang@tup.tsinghua.edu.cn 


EE: 
HERE 


全 国 新 华 书店 

: 203mmX260mm ED — 3K:355 字 $: 1021 FË 
Ch DVD 光盘 1 张 ) 

: 2014 年 1 月 第 1 版 印 X: 2014 年 1 月 第 1 次 印刷 

1~5000 

: 69.80 元 


WSR HAHI 


EI y 


产品 编号 : 053967-01 


Bii 


oll 


从 1995 年 发 布 PHP 1.0 以 来 ， 已 经 有 18 年 了 。 在 这 期 间 ，PHP 以 其 简单 易学 而 且 高 性 能 的 特点 
在 网 页 后 台 开 发 中 经 久 不 豪 ， 成 为 目前 最 流行 的 网 站 后 台 技术 之 一 ， 可 以 完成 任何 规模 的 站 点 开发 。 
因此 ， 现 在 许多 知名 网 站 ， 如 百度 、 腾 讯 、 新 浪 以 及 雅虎 ， 都 在 使 用 PHP 技术 。 现 在 流行 的 论坛 系统 ， 
如 Discuz! ， 就 是 完全 用 PHP 编写 的 。 

笔者 结合 自己 多 年 的 PHP 开发 经 验 和 心得 体会 ， 花 费 了 一 年 多 的 时 间 编 写本 书 ， 希 望 读者 能 在 本 
书 的 引领 下 跨 入 PHP 开发 大 门 ， 并 成 为 一 名 开发 高 手 。 本 书 结合 多 媒体 教学 视频 ， 人 全面、 系统、 深入 
地 介绍 了 PHP 开发 技术 ， 并 在 全 书 的 讲解 中 贯穿 了 大 量 实例 ， 最 后 还 详细 介绍 了 多 个 实例 的 开发 。 学 
习 完 本 书 ， 读 者 可 以 具备 独立 进行 项 目 开发 的 能 力 。 


本 书 特色 


1. 配套 大 量 多 媒体 语音 教学 视频 ， 学 习 效 果 好 

笔者 专门 录制 了 大 量 的 配套 多 媒体 语音 教学 视频 ， 以 便 读 者 更 加 轻松 、 直 观 地 学 习 本 书 内 容 ， 提 
高 学 习 效率 。 这 些 视频 和 书 中 实例 源 代码 一 起 收录 于 配 书 光盘 中 。 

2. 内 容 全 面 、 系 统 、 深 入 

本 书 介 绍 了 PHP 开发 的 基础 知识 、 界 面 开 发 、 数 据 库 开 发 、 网 络 编程 、 系 统 功能 编程 、 多 媒体 开 
发 等 内 容 ， 最 后 还 详细 介绍 了 两 个 项 目 案例 的 开发 。 

3. 讲解 由 浅 入 深 、 循 序 渐进 ， 适 合 各 个 层次 的 读者 阅读 

本 书 从 PHP 的 基础 知识 开始 讲解 ， 逐 步 深 入 到 PHP 的 高 级 开发 技术 及 应 用 ， 内 容 梯度 从 易 到 难 
讲解 由 浅 入 深 、 循序渐进 ， 适 合 各 个 层次 的 读者 阅读 。 

4. 贯穿 大 量 的 开发 实例 和 技巧 ， 可 迅速 提升 开发 水 平 

本 书 在 讲解 知识 点 时 贯穿 了 大 量 短小 精 悍 的 典型 实例 ， 并 给 出 了 大 量 的 开发 技巧 ， 以 便 读者 更 好 
地 理解 各 种 概念 和 开发 技术 ， 体 验 实际 编程 ， 迅 速 提高 开发 水 平 。 

5. 详解 典型 项 目 案例 开发 ， 提 高 实战 水 平 

本 书 详细 介绍 了 6 个 不 同 复杂 程度 的 案例 。 通 过 这 些 案例 ， 可 以 提高 读者 的 软件 项 目 开 发 水 平 ， 
从 而 具备 独立 进行 项 目 开 发 的 能 力 。 


本 书 内 容 及 体系 结构 


第 1 篇 PHP 准备 篇 GE 1—2 章 ) 
本 篇 主要 内 容 包括 : 初 识 PHP 和 PHP. 的 开发 环境 及 安装 。 通 过 本 篇 的 学 习 , 读者 可 以 了 解 什么 是 
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PHP 以 及 PHP 的 优势 ， 而 且 为 以 后 的 学 习 打 好 基础 。 

第 2 篇 PHP 基础 篇 (第 3 一 6 章 ) 

本 篇 主要 内 容 包括 : PHP 中 的 常量 与 变量 、PHP 中 的 运算 符 与 表达 式 、 PHP 中 的 流程 控制 以 及 PHP 
中 的 函数 。 通 过 本 篇 的 学 习 ， 读 者 可 以 掌握 PHP 的 基础 技术 ， 为 以 后 的 提升 打下 基础 。 

第 3 篇 PHP 进 阶 篇 (第 7 一 14 章 ) 

本 篇 主要 内 容 包括 : PHP 的 数据 处 理 、PHP 文件 应 用 、 用 PHP 获取 主机 信息 、PHP 中 的 图 像 处 理 、 
PHP 中 的 Session 与 Cookie、PHP 中 正则 表达 式 的 使 用 、PHP 面向 对 象 编程 以 及 使 用 MySQL 数据 库 。 
通过 本 篇 的 学 习 ， 读 者 可 以 掌握 PHP 中 的 高 级 技术 ， 为 开发 高 级 应 用 打下 基础 。 

第 4 篇 应 用 篇 〈 第 15 一 21 章 ) 

本 篇 主要 内 容 包括 : 用 PHP 实现 人 机 交互 、 计 数 器 程序 、 网 上 投票 程序 、 文 本 留言 板 程序 、PHP 
博客 程序 、 简 单 的 BBS 系统 以 及 网 上 商城 全 站 系统 。 通 过 本 篇 的 学 习 ， 读 者 可 以 掌握 开发 实际 应 用 的 
思想 和 方法 。 


本 书 读者 对 象 


PHP 初学 者 。 

想 全 面 学 习 PHP 开发 技术 的 人 员 。 
PHP 专业 开发 人 员 。 

利用 PHP 做 开发 的 工程 技术 人 员 。 
PHP 开发 爱好 者 。 

大 中 专 院 校 的 学 生 。 

社会 培训 班 学 员 。 

需要 一 本 案头 必 备 手册 的 程序 员 。 
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本 书 主要 由 葛 丽 萍 老师 〈 营 口 职业 技术 学 院 ) 完成 ， 其 中 葛 老 师 编 写 了 本 书 的 1 一 19 章 。 同 时 参 
与 编写 的 还 有 天 宇 峰 、 陈 冠军 、 张 燕 、 吴 金 攀 、 杨 锐 丽 、 鲍 洁 、 王 小 龙 、 李 亚 杰 、 张 育 梅 、 刘 媛 媛 、 
李 亚 伟 、 鲍 凯 、 张 晶 、 宋 强 。 由 于 编写 过 程 相对 匆忙 ， 书 中 难免 存在 错误 和 玻 漏 之 处 ， 敬 请 读者 不 将 
指出 。 
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第 1 篇 PHP 准备 篇 


本 篇 是 整 本 书 的 开头 ， 主 要 介绍 了 动态 网 站 开发 技术 、 构 建 PHP 环境 、 
第 一 个 程序 Hello World, PHP 的 数据 类 型 、 变 量 和 常量 以 及 运算 符 等 知识 。 
通过 本 篇 的 学 习 ,读者 能 够 掌握 基础 的 PHP 知识 并 搭建 好 PHP 环境 以 供 之 后 
的 学 习 使 用 。 

第 1 章 初 识 PHP 
第 2 章 PHP 的 开发 环境 及 安装 


第 1 章 初 识 PHP 


当前 网 络 技术 发 展 日 新 月 异 ， 各 种 基于 服务 端 创建 动态 网 站 的 脚本 语言 更 是 层出不穷 。 其 中 PHP 
以 其 简单 、 易 用 、 可 移植 性 强 等 特点 ， 在 众多 的 动态 网 站 语言 技术 中 独树一帜 。 到 底 什么 是 PHP， 如 
何 使 用 PHP? 本 章 将 回答 这 些 问 题 。 通 过 本 章 的 学 习 ， 读 者 将 会 对 PHP 有 一 个 大 致 的 了 解 ， 并 将 学 会 
把 PHP 代码 加 入 普通 Web 页 中 的 方法 。 


1.1 关于 静态 网 页 与 动态 网 页 


网 页 可 分 为 静态 网 页 与 动态 网 页 两 种 形式 。 在 讲解 这 两 种 网 页 之 前 ， 先 了 解 一 下 网 络 构 成 中 的 服 
务 器 (Server) 与 客户 机 (Client) 。 服 务 器 是 安装 有 服务 器 软件 并 且 可 以 向 客户 机 提供 网 页 浏览 、 数 
据 库 查询 等 服务 的 设备 。 而 客户 机 则 与 之 相反 ， 它 通过 客户 端 软件 〈 如 网 页 浏览 器 ) 从 服务 器 上 获得 
网 页 浏览 、 软 件 下 载 等 服务 。 简 单 地 讲 ， 服 务 器 就 是 服务 提供 者 ， 而 客户 机 则 是 服务 获得 者 。 


1.1.1 传统 的 静态 网 页 HTML 


GE 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 1 章 \ 传 统 的 静态 网 页 HTML.wmv 

在 WWW 发 展 的 早期 阶段 ， 由 于 受 技术 条 件 的 制约 ， 服 务 器 提供 给 用 户 的 网 页 基本 都 是 静态 的 
HTML 页 。 这 种 网 页 通常 只 包含 HTML 标识 ， 没 有 脚本 代码 。 这 类 网 页 在 视觉 上 也 可 能 出 现 “ 动 ”的 
效果 ， 如 通过 GIF 动画 、Flash、JavaScript 特效 等 内 容 来 丰富 网 页 。 但 是 客户 每 次 浏览 ， 该 网 页 的 内 容 
都 是 一 成 不 变 的 。 

静态 网 页 服务 的 实现 流程 如 下 : 客户 机 通过 浏览 器 向 服务 器 发 出 请 求 ， 服 务 器 根据 请 求 从 服务 器 
端的 网 页 中 选 出 合适 的 页 面 发 送 给 客户 机 浏览 器 。 这 个 过 程 中 所 发 送 的 页 面 都 是 事先 编辑 好 的 ， 它 并 
不 能 自动 生成 。 静 态 网 页 的 实现 模式 如 图 1.1 所 示 。 


图 1.1 静态 网 页 的 实现 模式 


1.1.2 


静态 网 页 不 能 自动 更 新 。 若 要 对 静态 页 面 进行 更 新 ， 就 要 重新 编写 HTML 页 ， 然 后 再 上 传 。 
因此 静态 网 页 的 制作 和 维护 工作 量 相当 大 。 

静态 网 页 的 内 容 不 随 浏览 用 户 、 浏 览 时 间 等 条 件 的 变化 而 变化 。 无 论 何 人 、 何 时 、 何 地 浏览 
网 页 ， 它 的 内 容 都 是 一 成 不 变 的 (不 包括 使 用 JavaScript 实现 的 一 些 简单 特效 )。 

静态 网 页 一 经 发 布 , 无 论 浏览 者 浏览 与 否 , 它 都 是 真实 存在 的 一 个 文件 , 都 对 应 一 个 URL. ( 统 
一 资源 定位 器 ， 指 Internet 文件 在 网 上 的 地 址 )。 

用 静态 网 页 实现 人 机 交互 有 相当 大 的 局 限 性 。 由 于 不 能 动态 生成 页 面 ， 所 以 用 静态 网 页 来 实 
现 人 机 交互 是 很 困难 的 ， 在 功能 上 有 很 大 限制 。 


动态 网 页 与 传统 网 页 的 区 别 


CA 知识 点 讲解 : 光盘 \ 视 频 讲 解 \ 第 1 章 \ 动 态 网 页 与 传统 网 页 的 区 别 .wmv 

随 着 网 络 技术 的 不 断 发 展 ， 各 种 动态 网 页 技术 也 纷纷 显露 出 它们 不 凡 的 魅力 。 先 是 早期 出 现 的 
CGI， 又 有 现在 流行 的 ASP、PHP、JSP、ASP.NET、ColdFushion 等 。 虽 然 这 些 动态 语言 分 属 不 同 公司 
开发 (其 中 ASP 与 ASP.NET 同属 微软 公司 ) ， 也 有 着 不 同 的 运行 环境 和 使 用 方法 ， 但 它们 的 目标 是 
一 样 的 ， 都 是 实现 网 页 浏览 者 与 网 页 之 间 的 互动 。 

与 静态 网 页 的 实现 方法 不 同 ， 动 态 网 页 服务 的 实现 流程 如 下 : 客户 机 向 服务 器 提出 申请 ， 服 务 器 
根据 用 户 请 求 ， 把 动态 网 页 内 部 的 代码 先 在 服务 器 上 进行 相应 的 处 理 ， 再 把 生成 的 结果 发 送 给 客户 机 。 
动态 网 页 的 实现 模式 如 图 1.2 所 示 。 


图 12 动态 网 页 的 实现 模式 
通过 以 上 分 析 可 知 ， 与 静态 网 页 相 比 ， 动 态 网 页 有 以 下 特点 : 


动态 网 页 在 服务 器 端 运行 。 客 户 机 上 看 到 的 只 是 它 的 返回 结果 ， 不 可 能 看 到 它 的 源 文 件 。 而 
静态 网 页 则 只 能 通过 服务 器 把 网 页 文件 原封 不 动 地 传 给 客户 机 ， 本 身 不 进行 任何 处 理 。 

不 同 的 人 、 不 同时 间 、 不 同 地 点 浏览 同一 个 动态 网 页 ， 根 据 代码 处 理 结果 不 同 ， 会 返回 不 同 
的 内 容 。 

动态 网 页 只 有 经 客户 浏览 时 才 会 返回 一 个 完整 的 网 页 ， 而 其 本 身 并 不 是 一 个 独立 存在 于 服务 
器 的 网 页 文件 。 

与 静态 网 页 相 比 ， 动 态 网 页 更 容易 实现 人 机 交互 。 与 数据 库 相 联系 ， 能 实现 更 为 强大 的 功能 。 
由 动态 网 页 构建 的 网 站 维护 起 来 比 由 静态 网 页 构建 的 网 站 容易 ， 只 需要 更 新 调用 的 数据 (如 


数据 库 内 容 ) 即 可 。 
© 


1.2 关于 PHP 


1.1 节 为 读者 介绍 了 静态 网 页 与 动态 网 页 ， 而 PHP 就 是 动态 网 页 技术 中 的 一 种 。 那 么 到 底 什么 是 
PHP， 它 的 发 展 历史 是 怎么 样 的 ? 与 其 他 动态 网 页 技术 相 比 ，PHP 有 什么 特点 ? 本 节 将 为 读者 解答 这 
些 问题 。 


1.2.1 什么 是 PHP 
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早期 有 人 将 PHP 解释 为 Personal Home Page， 即 个 人 主页 。 也 有 人 将 PHP 称 做 PHP: Hypertext 
Preprocessor (这 是 一 个 递归 的 简称 ， 简 称 之 中 又 是 简称 ) 。 那 么 到 底 什么 是 PHP WE? 通俗 地 说 ，PHP 
是 一 种 服务 器 端 、 跨 平台 、 可 以 嵌入 HTML 的 脚本 语言 。 服 务 器 端 执 行 的 特性 表明 它 是 动态 网 页 的 一 
种 。 跨 平台 ， 则 是 指 PHP 不 仅 可 以 运行 在 Linux 系统 下 ， 同 时 也 可 以 运行 在 UNIX 或 者 Windows 系统 
下 。 另 外 ， 它 还 可 以 很 简单 地 嵌入 到 普通 的 HTML 页 中 ， 用 户 所 要 做 的 只 是 在 普通 HTML 页 中 加 入 
PHP 代码 即 可 。 


1.2.2 PHP 的 发 展 历史 
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PHP 最 初 在 1994 年 由 Rasmus Lerdorf 进 行 开发 .用 户 使 用 的 第 1 个 版 本 是 在 1995 年 发 布 的 Personal 
Home Page Tools (PHP Tools) 。 在 该 PHP 版 本 中 只 提供 了 对 访客 留言 本 、 访 客 计 数 器 等 简单 功能 的 
支持 。1995 年 中 期 又 发 布 了 PHP 的 第 2 个 版 本 , 定名 为 PHP/FI (Form Interpreter) 。 到 1996 4E, PHP/FI 
2.0 已 经 应 用 于 分 布 在 世界 各 地 的 15000 个 网 站 上 。 

1997 年 开始 了 第 3 版 的 开发 计划 ， 开 发 小 组 加 入 了 Zeev Suraski 及 Andi Gutmans, mA 3 版 就 定 
名 为 PHP 3.0。 该 版 本 的 PHP 具有 以 下 特点 : 与 Apache 服务 器 紧密 结合 ;加 入 了 更 多 的 新 功能 ， 支 持 
几乎 所 有 主流 与 非 主流 数据 库 ， 高 速 的 执行 效率 等 。 由 于 PHP 3.0 的 这 些 特性 ， 使 得 1999 年 使 用 PHP 
的 网 站 超过 了 15 万 。 

2000 年 5 月 ，PHP 4.0 正式 发 布 ， 它 使 用 了 Zend (Zeev+Andi) 引擎 ， 提 供 更 高 的 性 能 ， 还 包含 了 
其 他 一 些 关键 功能 ， 如 支持 更 多 的 Web 服务 器 、HTTP Sessions 支持 、 输 出 缓存 Coutput buffering) ~ 
更 安全 的 处 理 用 户 输入 的 方法 以 及 一 些 新 的 语言 结构 等 。PHP 4.0 是 更 有 效 、 可 靠 的 动态 Web 页 开发 
工具 。 在 大 多 数 情况 下 运行 比 PHP 3.0 快 ， 其 脚本 描述 更 强大 并 且 更 复杂 ， 最 显著 的 特征 是 速率 比 
增加 。 

2004 年 7 月 ,PHP 5 问世 。 无 论 对 于 PHP 语言 本 身 还 是 PHP 的 用 户 来 讲 ，PHP 5 都 算得 上 是 一 个 
里 程 碑 式 的 版 本 。PHP 5 的 诞生 ， 使 PHP 编程 进入 了 一 个 新 时 代 。Zend IL 引擎 的 采用 、 完 备 的 对 象 模 
型 、 改 进 的 语法 设计 ， 使 得 PHP 成 为 一 个 设计 完备 、 真 正 具 有 面向 对 象 能 力 的 脚本 语言 。 

说 明 : 在 编写 本 书 时 ，PHP 最 新 稳定 版 本 为 5.4.14。 
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1.2.3. PHP 与 其 他 CGI 程序 相 比 较 
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同样 作为 服务 端 编程 语言 ，PHP 与 其 他 CGI 程序， 如 ASP.NET, JSP 等 相 比 较 有 其 自身 的 特点 ， 
主要 表现 在 以 下 儿 个 方面 : 
Web 服务 器 支持 方面 PHP 能够 被 Apache、 IIS 等 多 种 服务 器 支持 , 而 ASP 则 只 能 被 Windows 
系统 下 的 IS, PWS 所 支持 。 
运行 平台 的 支持 。PHP 能 够 很 好 地 运行 于 Linux. UNIX. Windows, FreeBSD 等 多 种 操作 系 
统 下 ， 而 ASP 只 能 运行 于 Windows 系统 下 。 虽 然 JSP 也 能 在 多 种 系统 下 得 到 支持 ， 但 必须 以 
有 Java 虚拟 机 为 前 提 。 
脚本 语言 不 同 。PHP 本 身 就 是 一 种 编程 语言 ， 它 吸收 了 C. Java 等 语言 的 特点 ， 是 综合 它们 
在 网 络 上 的 优势 而 开发 的 一 种 新 语言 。ASP 严格 来 说 并 不 是 一 种 单纯 的 编程 语言 ， 而 是 一 
网 络 编程 支持 环境 ， 它 支持 VBScript、JScript、perl 等 多 种 语言 ， 但 一 般 默 认 使 用 VB 作为 主 
要 编程 语言 。 而 JSP 使 用 Java 编程 语言 或 JavaScript 作为 脚本 语言 。 
数据 库 支持 不 同 。 PHP 通常 与 MySQL 数据 库 结 合 使 用 , 同时 它 还 支持 Oracle, Sybase, ODBC 
等 数据 库 。ASP 则 通常 与 同属 微软 公司 的 Access, MSSQL 等 数据 库 配 合 使 用 .JSP 则 使 用 JDBC 
来 实现 与 数据 库 的 连接 。 
面向 对 象 的 支持 不 同 。ASP 基本 上 是 由 组 件 所 构成 的 ， 而 组 件 是 对 象 的 使 用 模式 ， 因 此 ASP 
中 对 象 的 使 用 频率 非常 高 ， 可 以 说 处 处 都 是 对 象 。JSP 是 建立 在 可 重用 的 、 跨 平台 的 组 件 之 上 


A 
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程 的 ，PHP 5 的 出 现 改变 了 这 种 状况 ， 真 正 实现 了 面向 对 象 。 
1.3 第 一 个 程序 一 一 HELLO WORLD! 


学 习 一 门 新 的 编程 语言 ， 都 需要 从 最 基本 的 程序 开始 ， 约 定 俗 成 的 第 一 个 程序 就 是 “HELLO 
WORLD!”。 本 节 ， 就 来 介绍 怎样 在 PHP 编程 环境 中 实现 这 一 个 最 基本 的 程序 〈 读 者 在 学 习 本 节 之 前 
先 保证 已 经 构建 了 PHP 运行 环境 ， 如 果 没 有 请 参见 本 书 第 2 章 的 相关 内 容 ) 。 


1.3.1 页 面 中 加 入 PHP 代码 
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PHP 是 一 种 可 嵌入 的 语言 。 也 就 是 说 ， 它 可 以 很 方便 地 加 入 到 一 般 常 见 的 HTML. 页 中 。 用 户 请 求 
PHP 文件 时 ， 相 关 的 PHP 代码 先 在 服务 器 端 解释 执行 ， 生 成 新 的 HTML 信息 ， 再 连同 原 有 的 HTML 
代码 一 起 发 送 给 用 户 。 

【实例 1-1】 以 下 代码 讲解 怎样 向 普通 HTML 页 中 加 入 PHP 代码 。 


re | 实例 1-1: 怎样 向 普通 HTML 页 中 加 入 PHP 代码 
源码 路 径 光盘 \ 源 文件 \01\1-1.php 
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01 «html» 
02 «head» 

03 ctitle-HELLO WORLD!</title> 

04 </head> 

05 <body> 

06 ”<!-- 以 上 为 普通 HTML 代码 ， 以 下 为 PHP 代码 -> 

07 <?php 

08 echo "HELLO WORLD!"; /用 echo 打印 字符 串 
09 ?> 

10 «L-EL EZ PHP 代码 --> 

11 </body> 

12 </html> 


注意 : 这 里 只 是 做 一 个 简单 的 演示 ， 读 者 不 必 深 究 其 运行 原理 。 
在 PHP 运行 环境 下 执行 以 上 代码 。 结 果 如 图 1.3 所 示 。 


HELLO WORLD! 


13 “HELLO WORLD!” 执 行 结果 


单 从 执行 结果 来 看 上面 这 段 代码 确实 没有 比 单纯 的 HTML 代码 多 任何 东西 。 可 事实 上 并 非 如 此 ， 
页 面 中 显示 的 “HELLO WORLD!” 是 经 过 服务 器 的 解释 才 转 到 客户 端的 。 其 执行 机 理 如 图 1.4 所 示 。 


IIR | 
RE 
bx 
x 
* 
EE ( 


1.4 PHP 执行 机 理 

通过 实例 1-1 可 以 发 现 ， 把 PHP 代码 加 入 普通 HTML 页 中 ， 只 需要 在 HTML 页 中 加 入 PHP 代码 
的 标记 “<?”、“?>” 符 号 ， 这 些 符号 的 中 间 即 为 PHP 代码 ， 这 些 代码 会 先 在 服务 器 上 被 解释 ， 然 后 
结果 连同 普通 HTML 代码 一 起 返回 给 客户 浏览 器 。 实 例 1-1 中 的 PHP 代码 即 为 通过 PHP 中 的 echo 语 
句 ， 打 印 出 一 段 字 符 串 “HELLO WORLD!” o 

当然 ， 使 用 “<?”、“?>” 标 记 只 是 把 PHP 代码 加 入 到 普通 HTML 页 中 的 一 种 方法 ， 除 此 之 外 还 
有 以 下 儿 种 方法 : 

使 用 <?php ?> 标记 。 

使 用 <script language="PHP"></script> 标 记 。 

使 用 ASP 语言 的 <% %> 标 记 。 
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注意 : 应 谨慎 使 用 加 入 PHP 代 码 的 方法 <% %>， 因 为 如 果 服 务 器 配置 不 支持 这 种 方法 ， 相 应 的 代码 不 
会 被 执行 ， 而 是 原封 不 动 地 显示 给 用 户 。 


1.3.3 PHP 页 中 加 入 注释 
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每 种 语言 都 有 自己 的 注释 方法 ，PHP 也 不 例外 。 注 释 的 内 容 并 不 被 执行 ， 它 可 以 是 任何 内 容 。 通 
常 ， 注 释 的 目的 是 为 了 向 别人 说 明 自 己 的 程序 ， 所 以 应 该 是 对 程序 、 语 句 的 解释 。 一 个 好 的 程序 不 仅 
要 有 友好 的 、 完 善 的 代码 ， 同 时 也 要 有 清晰 的 、 易 于 理解 的 注释 。 在 程序 中 加 入 注释 是 对 自己 工作 的 
总 结 ， 也 是 对 别人 的 一 种 尊重 。 

下 面 采用 实例 1-1 来 说 明 怎样 在 PHP 代码 中 加 入 注释 。 

01 «html» 

02 <head> 

03 <title>HELLO WORLDI«/title» 

04 </head> 

05 <body> 

06 ”<!-- 以 上 为 普通 HTML 代码 ， 以 下 为 PHP 代码 -> 

07 <?php 

08 echo "HELLO WORLD!"; /使 用 echo 语句 打印 字符 串 

09 iP 

10 PHP 对 多 行内 容 的 注释 

11 这 里 有 多 行内 容 

12 而 

13 7 

14  «I-ELE2 PHP 代码 --> 

15 </body> 

16 </html> 


通过 以 上 实例 知道 ， 为 PHP 代码 加 入 注释 ， 通 常 有 两 种 方法 ， 一 种 是 单行 注释 使 用 “/” 标 记 ; 

另 一 种 是 多 行 注释 使 用 “/* */” 标 记 。 
注意 : 在 使 用 多 行 注释 标记 时 ， 一 定 不 要 使 用 多 重 注 释 。 如 下 面 的 注释 的 使 用 ， 必 然 会 引起 错误 。 

<? 

" 

这 里 是 注释 

n 

又 有 注释 出 现 了 ， 这 是 错误 的 

gi 


EPH 中 ， 多 行 注释 并 不 支持 嵌 套 。 
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1.8.8 文件 的 引用 
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PHP 支持 文件 的 引用 ， 这 意味 着 用 户 可 以 把 一 些 全 局 变量 、 专 用 函数 放 到 专门 的 文件 中 ， 需 要 时 
来 引用 这 个 文件 。 文 件 被 引用 ， 就 可 以 使 用 其 中 的 变量 和 函数 了 ， 就 像 在 一 个 PHP 文件 中 一 样 方便 。 
PHP 有 两 种 引用 文件 的 方法 : require 和 include()。 下 面 通过 一 个 实例 来 说 明 这 两 种 方法 。 


<?php 
$string="HELLO WORLD!"; /定义 变量 
?» 


这 段 代 码 只 是 定义 了 一 个 字符 串 变 量 。 把 上 面 的 代码 保存 为 一 个 PHP 文件 ， 如 string.php。 
【实例 1-2】 以 下 代码 演示 包含 上 面 定义 的 string.php 文件 。 


re 实例 1-2: 包含 string.php 文件 
源码 路 径 ， 光盘 \ 源 文件 \01\1-2.php 


02 <head> 

03 ”<title> 使 用 include 引用 文件 </title> 

04 </head> 

05 <body> 

06 <?php 

07 include("string.php"); /使 用 include() 方 法 引用 文件 
08 echo $string; 


在 PHP 环境 里 执行 1-2.php， 执 行 结果 与 图 1.3 相同 。 
同 理 还 可 以 用 

require "文件 名 "; 

来 引用 文件 ， 使 用 效果 与 

include(" 文 件 名 "); 

是 一 样 的 。 


MBA: require 和 include() 方 法 的 区 别 在 于 , 如 果 所 包含 文件 出 现 错误 ,include() 产 生 一 个 警告 ; 而 require 
则 导致 一 个 致命 错误 。 也 就 是 说 ，require 会 导致 程序 终止 。 


14 本 章 小 结 


本 章 介绍 了 PHP 的 基础 知识 ， 包 括 静 态 网 页 与 动态 网 页 、 什 么 是 PHP. PHP 的 发 展 历史 、 在 页 面 
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中 加 入 PHP 代码 和 注释 以 及 PHP 对 文件 的 引用 。 通 过 本 章 的 学 习 , 读者 对 什么 是 PHP 及 怎样 使 用 PHP 
应 该 有 一 个 大 致 的 了 解 。 


1.5 A €* JÄ 


习题 1-1 动态 网 页 与 静态 网 页 的 主要 区 别 是 什么 ? 
【分 析 】 该 习题 主要 考查 读者 对 动态 网 页 和 静态 网 页 最 主要 区 别 的 理解 。 
习题 1-2 动态 网 页 相 比 静态 网 页 的 优势 在 哪里 ? 
【分 析 】 该 习题 主要 考查 读者 对 动态 网 页 优势 的 理解 ， 以 使 读者 可 以 在 以 后 利用 这 些 优势 。 
习题 1-3 将 下 面 的 代码 作为 PHP 代码 写 入 一 个 名 为 testl.php 的 源 文件 中 。 
echo "Good!"; 
【分 析 】 该 习题 主要 考查 读者 对 PHP 代码 开始 和 结束 符号 的 记忆 。 
习题 1-4 在 习题 1-3 中 写 入 的 PHP 代码 后 添加 如 下 注释 。 
这 是 一 条 输出 语句 。 
【分 析 】 该 习题 主要 考查 读者 对 PHP 注释 的 记忆 。 
习题 1-5 ”新 建 一 个 PHP 源 文件 test2.php， 并 在 文件 中 引用 前 面 完 成 的 testl.php 文件 。 
【分 析 】 该 习题 主要 考查 读者 对 PHP 文件 引用 的 掌握 。 
【关键 代码 】 
require "test1.php" 
或 者 
include ("test1.php") 


Ber PHP 的 开发 环境 及 安装 


通过 第 1 章 的 学 习 ， 读 者 知道 PHP 是 一 种 服务 端 编 程 语言 。 所 以 要 想 运行 PHP 代码 ， 必 须 得 有 相 
应 的 服务 器 环境 及 解释 器 。PHP 能 够 在 多 种 服务 器 环境 下 运行 ， 但 是 PHP 的 “黄金 搭配 ”是 
PHP+Apache+Linux 。 作 为 通用 操作 系统 ，Linux 远 没 有 Windows 那么 流行 。 所 以 本 书 的 环境 就 采用 
PHP+Apache+Windows 这 样 的 形式 。 本 章 将 介绍 在 Windows 操作 系统 下 安装 、 配 置 PHP 的 运行 环境 。 
调试 PHP 程序 需要 安装 以 下 组 件 。 
Apache: 运行 Web 页 面 的 服务 器 程序 。 
PHP: PHP 程序 的 解释 器 。PHP 页 面 会 先 通过 该 解释 器 解释 再 发 送 给 用 户 。 
MySQL: MySQL 数据 库 程序 。 调 试 数 据 库 程序 的 必 备 服务 。 
phpMyAdmin: 用 PHP 编写 的 管理 MySQL 数据 库 的 程序 。 使 用 该 程序 可 以 有 效 管理 MySQL 
数据 库 。 
EditPlus: PHP 文件 的 编辑 器 。 可 以 编辑 任何 二 进 制 文件 。 
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2.1 Windows 平台 下 Apache 的 安装 
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Apache 是 运行 PHP 程序 最 好 的 服务 器 系统 , 通常 情况 下 Apache 都 是 运行 在 Linux 操作 系统 下 的 。 
Apache 服务 器 也 有 Windows 版 本 ， 本 书 就 采用 Apache 的 Windows 版 本 来 搭建 服务 器 环境 。 
Apache 可 以 在 其 官方 网 站 http:/www.apache.org 上 下 载 。 本 书 使 用 Apache_2.2.22 版 本 〈 其 实 不 同 
版 本 的 区 别 对 初学 者 来 说 不 是 太 大 ) 。 下 载 得 到 的 是 一 个 Msi 文件 ， 双 击 即 可 安装 。 最 简单 的 方法 是 
采用 一 路 回 车 法 即 可 ， 不 过 其 中 有 几 项 还 是 要 向 读者 做 一 下 介绍 。Apache 的 安装 共 分 以 下 几 步 。 
说 明 : 官网 还 提供 了 其 他 形式 的 安装 包 ， 如 UNIX 源 文件 形式 的 “.tar.bz2”、“.tar.gz” 以 及 “.zip” 形 
式 的 安装 包 。 
CD. 首先 弹出 的 是 欢迎 使 用 界面 。 单 击 Next 按钮 ， 进 入 License Agreement 界面 ， 如 图 2.1 所 示 。 
(2) 选中 accept the terms in the license agreement 单 选 按钮 ， 单 击 Next 按钮 ， 进 入 下 一 个 界面 。 
(3) 该 界面 是 对 Apache 的 简单 介绍 。 单 击 Next 按钮 ， 进 入 Server Information 界面 ， 如 图 22 
所 示 。 
(4) 在 Network Domain 文本 框 中 输入 域名 。 如 果 只 是 在 本 机 上 调试 程序 ， 并 不 是 想 架设 一 台 网 
络 服务 器 ， 只 需 填 入 本 机 IP (127.0.0.1) 即 可 。 在 Server Name 文本 框 中 输入 服务 器 的 名 字 ， 这 里 输入 
localhost. E Administrator's Email Address 文本 框 中 输入 网 络 管理 员 的 电子 信箱 .for All Users, on Port 80, 
as a Service-Recommended. 单 选 按钮 为 允许 所 有 用 户 使 用 Apache 服务 ; only for the Current User, on Port 
8080, when started manuall. 单 选 按钮 只 允许 当前 用 户 使 用 Apache 服务 。 这 里 选择 第 一 项 。 单 击 Next 按 
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钮 ， 进 入 Setup Type 界面 ， 如 图 2.3 所 示 。 
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图 2.1 License Agreement 界面 图 2.2 Server Information 界面 


注意 : 如 果 想 要 让 其 他 计算 机 访问 网 站 ， 需 要 检查 防火 墙 的 设置 。 


(5) Typical 选项 为 标准 安装 ，Custom 选项 为 自 定义 安装 ， 这 里 选择 Custom 选项 。 单 击 Next 按 
钮 ， 进 入 Custom Setup 界面 ， 如 图 2.4 所 示 。 
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2.3 Setup Type 界面 图 2.4 Custom Setup 界面 


C6) 单 击 Change 按 钮 ,选择 安装 目录 ,默认 为 C\Program files。 为 了 调试 方便 , 这 里 选择 C:\Apache。 
单 击 Next 按钮 ， 进 入 Ready to Install the Program 界面 ， 如 图 2.5 所 示 。 
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图 2.5 Ready to Install the Program 界面 
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C7) 单 击 Install 按钮 开始 进行 安装 。 安 装 结束 后 ， 进 入 Installation Wizard Completed 界面 ， 如 
图 2.6 所 示 。 
(8) 该 界面 提示 用 户 Apache 已 经 安装 成 功 ， 单 击 Finish 按钮 完成 安装 。 
安装 成 功 后 ， 打 开 IE 输入 http:/127.0.0.1， 结 果 如 图 2.7 所 示 。 至 此 ，Apache 的 安装 过 程 全 部 结束 。 
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图 2.6 Installation Wizard Completed 界面 图 2.7 测试 成 功 Apache 正常 工作 
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本 节 来 完成 PHP 的 安装 及 相关 配置 。 因 为 Apache 只 支持 传统 的 HTML, ERU S PHP 的 魅力 ， 
必须 要 安装 PHP 解释 器 。 与 Apache 相 比 ，PHP 解释 器 的 安装 要 简单 一 些 ， 因 为 PHP 解释 器 通常 是 以 
ZIP 包 的 形式 提供 ， 只 需 在 解压 缩 后 ， 进 行 相关 配置 即 可 。 

PHP 解释 器 可 以 从 其 官方 网 站 http://www.php.net/ 上 获取 。 这 里 选择 php-5.4.14 的 Win32 版 。 该 版 
本 提供 两 种 形式 ,一 种 是 安装 包 的 形式 ， 另 一 种 是 ZIP 包 的 形式 , 这 里 选用 ZIP 包 形 式 。 把 下 载 的 ZIP 
压缩 包 解 压 到 C dit PHP 目录 下 。 解 压缩 后 ， 需 要 做 以 下 几 步 工作 。 
说 明 : 这 里 的 安装 包 名 为 php-5.4.14-Win32-VC9-x86.zip。 

CD 将 如 下 内 容 复 制 到 Apache 的 配置 文件 httpd.conf 〈 该 文件 位 于 C:\Apache\conf F) 。 


ScriptAlias /php/ "c:/php/" 
AddType application/x-httpd-php .php 


# For PHP 4 
Action application/x-httpd-php "/php/php.exe" 


# For PHP 5 
Action application/x-httpd-php "/php/php-cgi.exe" 


LoadModule php5 module "c:/php/php5apache2 2.dll" 
AddType application/x-httpd-php .php 


[ON 
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# configure the path to php.ini 
PHPlniDir "C:/PHP" 
(2) dE C fF php.ini-production 改名 为 php.ini。 
G) 右 击 Windows RÆK, XEFE open apache monitor 命令 ， 打 开 Apache 管理 器 ， 如 
图 2.8 所 示 。 
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图 2.8 Apache 管理 器 


(4). 单 击 Restart 按钮 ， 重 启 Apache 服务 即 可 。 
【实例 2-1】 以 下 代码 测试 Apache 对 PHP 的 支持 。 


01 <?php 
02 phpinfo(); 
03 ?> 


在 浏览 器 中 输入 http://localhost/2-1.php， 结 果 如 图 2.9 所 示 。 出 现 该 界面 说 明 PHP 安装 成 功 。 
说 明 : 也 可 以 在 浏览 器 中 输入 http://127.0.0.1/2-1.php 来 测试 。 
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图 2.9 2-1.php 执行 结果 
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2.3 MySQL 的 安装 和 配置 


PHP 通常 与 MySQL 数据 库 配 合 使 用 ， 所 以 学 习 PHP 就 必须 学 习 MySQL 数据 库 技术 。 因 此 ， 读 
者 需要 安装 MySQL 数据 库 。 这 一 节 来 介绍 如 何 获取 与 安装 MySQL 数据 库 。 


2.3.4 MySQL 的 安装 


YA 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 2 章 \MySQL 的 安装 .wmv 

读者 首先 应 到 MySQL 的 官方 网 站 http://www.mysql.com 下 载 MySQL 的 Windows 版 本 ,通常 下 载 
的 是 一 个 Msi 的 安装 包 ， 直 接 双击 运行 该 安装 程序 即 可 。 整 个 安装 过 程 共 分 以 下 几 步 : 
说 明 : 这 里 下 载 的 安装 包 名 为 mysql-installer-community-5.6.11.0.msi。 


(1) 首先 弹出 欢迎 界面 ， 单 击 Install MySQL Products 按钮 ， 进 入 License Agreement 界面 ， 如 
图 2.10 所 示 。 
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图 2.10 License Agreement 界面 


(2) 在 选中 I accept the license terms 复 选 框 后 单 击 Next 按钮 ， 进 入 Find latest products 界面 ， 如 
图 2.11 所 示 。 

(3) 选中 Skip the check for updates(not recommended) 复 选 框 后 ， 单 击 Next 按钮 ， 进 入 Choosing a 
Setup Type 界面 。 

(4)MySQL 提供 5 种 安装 模式 。 Developer Default 为 标准 安装 ; Server only 为 只 安装 服务 器 ; Client 
only 为 只 安装 客户 端 ，Full 为 完全 安装 ;Custom 为 自 定义 安装 。 这 里 选中 Custom 单 选 按钮 ， 并 将 
Installation Path 改 为 CN\MySQL\， 将 Data Path 改 为 C:\IMySQL\IMySQL Server 5.6\， 如 图 2.12 所 示 。 
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图 2.11 Find latest products 界面 
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图 2.12 Choosing a Setup Type 界面 


C5) 单 击 Next 按钮 ， 进 入 Feature Selection 界面 。 这 里 只 选中 MySQL Server 5.6.11 复 选 枉 ， 如 
图 2.13 所 示 。 
(6) 单 击 Next 按钮 ， 进 入 Check Requirements 界面 。 单 击 Next 按钮 ， 进 入 Installation Progress 


界面 。 


(7) 在 确认 安装 信息 后 单 击 Execute 按钮 开始 安装 。 
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(8) 在 安装 完成 后 ， 单 击 Next Jl, 3E Configuration Overview 界面 ， 如 图 2.14 所 示 。 
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图 2.13 Feature Selection 界面 
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2.14 Configuration Overview 界面 
单 击 Next 按钮 ， 完 成 安装 过 程 ， 开 始 对 MySQL 服务 进行 配置 。 


2.8.2 MySQL 的 配置 


GIA 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 2 MySQL 的 配置 .wmv 
在 安装 完成 后 ， 开 始 对 MySQL 服务 进行 配置 。 整 个 配置 过 程 也 由 以 下 儿 步 组 成 。 
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(1) 首先 进入 MySQL 服务 器 配置 的 第 一 步 ， 如 图 2.15 所 示 。 
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图 2.15 MySQL 配置 过 程 第 一 步 


(2) 这 里 选择 默认 配置 即 可 ， 然 后 单 击 Next 按钮 ， 进 入 MySQL 服务 器 配置 的 第 二 步 ， 如 图 2.16 
所 示 。 
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图 2.16 MySQL 配置 第 二 步 


G) 在 为 Root 用 户 设置 密码 后 单 击 Next 按钮 ， 进 入 MySQL 服务 器 配置 的 第 三 步 ， 如 图 2.17 所 示 。 

(4) 这 里 也 使 用 默认 配置 即 可 ， 然 后 单 击 Next 按钮 执行 配置 ， 如 图 2.18 所 示 。 

(5) 在 配置 执行 完毕 后 单 击 Next 按钮 进入 Installation Complete 对 话 框 ， 如 图 2.19 所 示 。 单 击 Finish 
按钮 即 可 完成 配置 。 
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2.17 MySQL 配置 第 三 步 
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图 2.19 完成 MySQL 服务 器 配置 
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至 此 ， 整 个 MySQL 服务 器 配置 过 程 完成 。 

2.3.3 修改 php.ini 以 支持 MySQL 
EI 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 2 章 \ 修 改 php.ini 以 支持 MySQL.wmv 
打开 CAphp 目录 下 的 php.ini 文件 。 找 到 


;extension=php_mysql.dll 
;extension-php mysgli.dll 


这 一 行内 容 。 去 掉 前 面 的 分 号 ， 保 存 php.ini 文件 。 重 新 启动 服务 器 即 可 让 PHP 支持 MySQL. 


E og ”实例 2-2: 演示 MySQL RARER IERT 
源码 路 径 ; 光盘 \ 源 文件 ,02\2-2.php 


01 <?php 
02 Slink=mysql_connect("localhost','root',"admin'); // 该 函数 是 进行 MSYQL 主机 连接 的 函数 , 其 中 的 
root 和 空 密码 是 MYSQL 的 用 户 和 密码 ， 请 根据 自己 的 情况 改 好 


03 if(ISlink) echo "失败 "; // 如 果 连 接 失败 ， 则 输出 失败 信息 
04 else echo "成 功 "; // 如 果 连 接 成 功 ， 则 输出 成 功 信息 
05 mysql close(); 

06 ?> 


注意 : 读者 无 需 完全 理解 这 里 的 代码 的 作用 ， 相 关 的 内 容 会 在 后 面 章节 中 介绍 。 
先 开 启 MySQL 服务 。 开 启 MySQL 服务 器 有 以 下 方法 : 
在 命令 行 中 执行 如 下 命令 : 
net start mysql5.6 
在 服务 中 启动 MySQLS.6. 
说 明 : 可 以 在 启动 菜单 中 搜索 “服务 ”关键 字 来 打开 服务 管理 。 
然后 在 PHP 运行 环境 下 执行 2-2.php， 执 行 结果 如 图 2.20 所 示 。 


感 hip/localhosuy2- £ 
图 2.20 测试 MySQL 是 否 成 功 安装 

出 现 如 图 2.20 所 示 结 果 ， 说 明 MySQL 已 经 正常 运行 。 
技巧 : 如 果 不 能 正常 访问 ， 建 议 读者 检查 用 户 名 与 密码 是 否 匹配 。 
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2.4 XX phpMyAdmin 
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安装 完 MySQL 数据 库 后 ， 要 建 库 、 表 ， 修 改 各 种 数据 库 、 表 等 工作 。 如 果 这 些 工 作 都 在 命令 行 
模式 下 进行 ， 一 方面 非常 麻烦 ， 另 一 方面 也 需要 有 专业 的 SQL 数据 知识 才 行 。 可 喜 的 是 ， 现 在 已 经 有 
了 可 视 化 的 MySQL 数据 管理 工具 phpMyAdmin。 该 工具 采用 PHP 编写 ， 可 以 完美 运行 在 各 种 版 本 的 
PHP 及 MySQL 下 。 本 节 来 讲解 如 何 安装 phpMyAdmin. 

用 户 可 以 通过 网 站 http:/sourceforge.netprojects/phpmyadmin/ 下 载 到 phpMyAdmin 的 最 新 版 本 。 安 
装 过 程 分 以 下 几 步 。 
说 明 : 本 书 编写 时 ， 当 前 最 新 版 本 为 3.5.8 版 。 读 者 下 载 时 ， 可 以 考虑 使 用 更 新 的 版 本 。 


(1) 把 下 载 到 的 压缩 包 解 压 到 C:\apache\htdocs\ 目 录 下 ， 把 目录 改名 为 phpmyadmin. 
(2) 复制 libraries/config.default.php 到 phpmyadmin 目录 下 ， 并 改名 为 config.inc.php 。 
(3) 找到 config.inc.php 中 的 如 下 代码 : 


Scfg['Servers'][Si][ user] = 'root'; IIMySQL user 
$cfg['Servers"][Si]|password'] = "; /MySQL password (only needed) 


注意 : 这 里 的 password 为 安装 MySQL 时 设置 的 密码 。 


把 其 中 的 内 容 替 换 为 MySQL 的 用 户 名 和 相应 的 密码 即 可 。 读 者 还 需要 测试 phpMyAdmin 是 否 正 
常 工作 。 在 浏览 器 中 输入 http://127.0.0.1/phpmyadmin/index.php， 其 执行 结果 如 图 2.21 所 示 。 


OT MZ 


phpMyAdmin 
| Gm Eso aus «m^ th mA ZUR 理 多 


OE ECE ETE] 

ma 可 数据 库 服务 器 
LIS 可 | 

Ya * 5:8. locals via TCP/IP 
3 information schema 5 . EPF MYSAL 

= prziti o MY 
D i "1 I * &fHET- 5611- MySQL 
uS omend A Communiy Savar (FL) 
3 performance. schema A roe 
"as | * AP: rootéllocalhost 


E ER - Languace 9 


*h 3t - Chinese simpliied 可 Fish 


9 xs| pmahomme[v] 


a * el22.22 132) 

- &|£* [v] pr veria) 
* PBEEPURÉA. ibmysq- 
P Esaa megna 50 10. om- 


707c415db32080b3752b232487 
s 


| “PHP 扩 展 :mysqi © 
v| 


图 2.21 phpMyAdmin 执行 结果 
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出 现 以 上 画面 说 明 phpMyAdmin 正常 运行 ，phpMyAdmin 安装 完成 。 
2.5 EditPlus 的 安装 
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PHP 文件 属于 二 进 制 文件 ， 所 以 可 以 采用 所 有 通用 的 文本 编辑 器 进行 编辑 ， 如 常见 的 记事 本 、 写 
字 板 、Word 等 。 不 过 这 些 程序 都 不 是 专 为 编写 程序 代码 而 设计 的 ， 在 编写 代码 时 功能 有 限 。 这 里 为 读 
者 推荐 一 款 功能 强大 的 文本 编辑 软件 一 一 EditPlus。 

用 户 可 以 在 官方 网 站 http://www.editplus.com/ 上 下 载 到 EditPlus。 该 软件 及 补丁 与 普通 软件 一 样 ， 
安装 过 程 相当 简单 ， 这 里 不 再 袭 述 。 安 装 后 ， 运 行 该 软件 ， 打 开工 具 菜 单 下 的 Configure User Tools 对 
话 框 ， 选 择 FilelSettings & syntax 命令 ， 出 现 如 图 2.22 所 示 对 话 框 。 


说 明 : 本 书 当 前 使 用 的 是 最 新 的 3.51 版 ， 读 者 在 使 用 时 可 以 选择 最 新 的 版 本 。 


MJAdd to 'Commor Files — ("Associate in Explorsr 
IV] Show HTML toolbar [Trim traiing spaces on save 


y OK X Cace 


图 2.22 EditPlus 的 配置 


在 右上 方 的 File types 列表 框 中 选择 PHP， 然 后 选中 右 下 方 的 Associate in Explorer 复 选 枉 ， 单 击 
Apply 按钮 。 这 样 所 有 的 PHP 文件 默认 被 EditPlus 打开 ， 完 成 配置 。PHP 的 开发 环境 全 部 安装 完毕 。 


说 明 : 在 互联 网 上 也 有 相应 的 汉化 版 本 可 以 使 用 。 
26 本 章 小 结 


开发 环境 是 进行 PHP 编程 的 基础 ， 只 有 有 了 相应 的 环境 才能 进行 开发 。 本 章 内 容 中 Apache 的 安 
装 相对 简单 ， 而 PHP 安装 过 程 中 由 于 要 修改 配置 文件 ， 所 以 相对 麻烦 。 而 且 由 于 版 本 兼容 性 问题 ， 有 
时 需要 安装 相应 补丁 才能 正常 运行 ， 这 一 点 需要 读者 引起 注意 。 
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习题 2-1 在 你 的 操作 系统 中 安装 Apache 服务 器 。 
【分 析 】 该 习题 主要 考查 读者 部 署 服 务 器 的 能 力 ， 同 时 也 为 后 续 学 习 搭建 好 环境 。 
习题 2-2 在 你 的 操作 系统 中 安装 PHP 解释 器 。 
【分 析 】 该 习题 主要 考查 读者 安装 和 配置 PHP 解释 器 的 能 力 ， 同 时 也 为 后 续 学 习 搭建 好 环境 。 
习题 2-3 在 你 的 操作 系统 中 安装 MySQL 数据 库 。 
【分 析 】 该 习题 主要 考查 读者 部 署 数据 库 的 能 力 ， 同 时 也 为 后 续 学 习 搭建 好 环境 。 
习题 2-4 在 你 的 操作 系统 中 安装 phpMyAdmin 数据 库 管理 工具 。 
【分 析 】 该 习题 主要 考查 读者 对 Apache 主 目录 的 掌握 ， 同 时 也 为 后 续 学 习 提供 一 个 优秀 的 管理 
工具 。 
习题 2-5 在 你 的 操作 系统 中 安装 EditPlus 文件 编辑 器 。 
【分 析 】 该 习题 主要 为 读者 在 后 续 的 学 习 过 程 中 提供 一 个 易 用 的 文本 编辑 器 。 


第 2 篇 PHP 基础 篇 


本 篇 介绍 PHP 中 的 变量 与 常量 、 运 算 符 与 表达 式 、 流 程控 制 以 及 函数 。 
该 篇 是 PHP 的 基础 篇 ,本 篇 主要 讲解 了 PHP 这 门 语言 的 基本 使 用 方法 。 通 过 
本 篇 的 学 习 ， 读 者 会 掌握 PHP 的 基础 语法 ， 可 以 编写 一 些 简 单 的 应 用 。 

第 3 章 PHP 中 的 常量 与 变量 

第 4 章 PHP 中 的 运算 符 与 表达 式 
第 5 章 PHP 中 的 流程 控制 

第 6 章 PHP 中 的 函数 


第 3 章 ”PHP 中 的 常量 与 变量 


常量 与 变量 是 构成 程序 的 重要 基石 ， 所 以 每 种 编程 语言 中 都 会 有 本 类 语言 所 对 应 的 常量 与 变量 。 
作为 一 门 网 络 编程 语言 ，PHP 也 不 例外 。 本 章 就 来 详细 介绍 有 关 PHP 中 的 常量 与 变量 的 知识 。 通 过 本 
章 的 学 习 ， 读 者 将 会 认识 到 什么 是 常量 、 变 量 ， 在 PHP 中 如 何 使 用 预定 义 常量 与 变量 ， 如 何 自 定义 常 


量 与 变量 等 。 
3.1 PHP 中 常量 的 定义 与 使 用 


常量 是 在 程序 运行 中 值 始 终 不 会 发 生 改变 的 一 类 量 。 在 进行 PHP 编程 时 经 常 要 用 到 这 类 数据 ， 如 
文件 名 、 文 件 的 路 径 等 系统 常量 以 及 用 户 自 定义 的 一 些 常量 。 本 节 来 介绍 PHP 中 的 常量 。 


3.1.1 定义 与 使 用 常量 
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在 PHP 中 使 用 define() 函 数 来 定义 常量 。 其 语法 格式 如 下 : 
define("Name","value"); 
其 中 的 Name 为 定义 常量 的 常量 名 ，value 为 常量 代表 的 值 。 
注意 : 常量 在 使 用 前 必须 定义 ， 和 否则 程序 在 执行 时 就 会 出 错 。 
【实例 3-1】 以 下 代码 介绍 PHP 中 常量 的 定义 与 使 用 。 


区 E 实例 3-1; 介绍 PHP 中 常量 的 定义 与 使 用 
. b | 源码 路 径 : 光盘 \ 源 文件 \03\3-1.php 


01 <html> 

02 <head> 

03 ”<title>PHP 中 常量 的 定义 与 使 用 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 define("STANDARD H","HELLO WORLD!"); //zE Y. 5538 STANDARD H, 并 赋值 为 HELLO WORLD! 
08 echo STANDARD H; /使 用 echo 打印 常量 
09 ?> 

10 </body> 

11 </html> 


在 PHP 运行 环境 下 执行 以 上 代码 ， 执 行 结果 如 图 3.1 所 示 。 


wis pPedmRSER (0 


o E hapyecaltosy:- £ 
HELLO WORLD! 


图 3.1 定义 与 使 用 常量 实例 执行 结果 

常量 的 命名 不 是 随意 的 ， 必 须 符合 一 定 的 规则 。PHP 中 常量 的 命名 有 以 下 规则 : 合法 的 常量 名 以 
字母 或 下 划 线 开始 ， 后 面 可 以 为 任何 字母 、 数 字 或 下 划 线 。 

常量 与 变量 的 不 同 之 处 体现 在 以 下 几 个 方面 : 
常量 前 面 没 有 美元 符号 〈$)， 而 变量 则 必须 以 美元 符号 开头 。 
常量 只 能 用 define() 函 数 定义 ， 而 不 能 通过 赋值 语句 定义 。 
常量 可 以 不 用 理会 变量 范围 的 规则 ， 可 以 在 任何 地 方 定义 和 访问 。 
常量 一 旦 定义 就 不 能 被 重新 定义 或 者 取消 定义 ， 并 且 其 值 不 能 发 生 改变 ， 而 变量 的 值 可 以 随 
时 发 生 改变 。 这 也 是 常量 与 变量 最 根本 的 不 同 。 
常量 的 值 只 能 是 标量 ， 即 整 型 、 浮 点 型 、 字 符 串 3 种 类 型 。 


3.1.2 PHP 中 的 预定 义 常量 
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除了 使 用 自 定 义 常量 之 外 ，PHP 还 为 用 户 预定 义 了 系统 常量 ， 常 见 的 系统 常量 及 其 含义 如 表 3.1 
所 示 。 
表 3.1 PHP 中 的 预定 义 常量 

常 量 名 yi — 明 

FILE PHP 文件 的 文件 名 

LINE PHP 文件 的 行 数 
PHP VERSION PHP 程序 的 版 本 ， 如 '5.4.14' 
PHP OS 执行 PHP 解释 器 的 操作 系统 名 称 ， 如 "Windows' 
TRUE 真 
FALSE 假 
E ERROR 最 近 的 错误 处 
E WARNING 最 近 的 警告 处 
E_PARSE 剖析 语法 有 潜在 问题 处 
E NOTICE 发 生 不 寻常 但 不 一 定 是 错误 处 


表 中 以 “E_” 开 头 的 常量 ， 可 以 参考 Error_Reporting() 函 数 。 
【实例 3-2】 以 下 代码 演示 PHP 中 预定 义 常量 的 应 用 。 
区 " | 实例 3-2. PHP 中 预定 义 常量 的 应 用 

源码 路 径 ， 光 盘 \ 源 文件 \03\3-2.php 


02 <head> 
03 ”<title>PHP 中 预定 义 常量 的 应 用 实例 </title> 
04 </head> 


KA aa 


05 «body» 

06 <?php 

07 echo "所 使 用 的 文件 名 是 : "; 

08 echo FILE ; /输出 当前 文件 名 
09 echo "<br>"; /输出 HTML 换行 符 
10 echo "文件 的 行 数 为 :"; 

11 echo LINE ; /| 输出 文件 行 数 

12 echo "<br>"; 

13 echo "PHP 的 版 本 是 : "; 

14 echo PHP. VERSION; /输出 PHP 版 本 

15 echo "<br>"; 

16 echo "所 使 用 的 操作 系统 为 :"; 

17 echo PHP. OS; // 输 出 操作 系统 类 型 
18 ?> 

19 </body> 

20 «html» 


在 PHP 运行 环境 下 执行 以 上 代码 ， 执 行 结果 如 图 3.2 Bras. CASS Scal x HERE RAE. PHP 
版 本 的 不 同 而 有 所 出 入 ， 但 大 体 上 是 一 样 的 ) 。 
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Pine. 
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图 3.2 使 用 PHP 中 的 预定 义 常量 实例 执行 结果 
注意 : 不 论 是 使 用 自 定义 常量 还 是 系统 预定 义 常量 ， 大 小 写 都 必须 一 致 。 如 使 用 系统 预定 义 常量 时 把 
大 写 改 为 小 写 ， 就 不 能 正确 返回 预定 义 常 量 PHP_VERSION 所 定义 的 PHP 版 本 号 ， 而 是 返回 
"php version" 64$. 
【实例 3-3】 以 下 代码 演示 错误 的 常量 使 用 方式 。 


01 <?php 

02 echo PHP VERSION; /1/ 输 出 PHP 版 本 

03 echo "<p>"; /| 输出 HTML 换行 符 
04 echo php version; // 输 出 字符 串 

05 ?> 


3.3 ”预定 义 常量 中 的 大 小 写实 例 执行 结果 


$35 PHP ORES 


从 图 3.3 可 以 发 现 ， 大 小 写 不 同 ， 所 输出 的 结果 不 同 。 所 以 ,使 用 系统 预定 义 常量 时 ， 一 定 要 注意 
大 小 写 问题 。 


32 PHP 中 的 变量 


变量 是 指 在 程序 运行 过 程 中 值 可 以 随时 发 生 改变 的 一 类 值 。PHP 是 一 个 弱 类 型 的 语言 〈 弱 类 型 语 
言 是 指 在 使 用 变量 时 不 用 指定 变量 的 类 型 ， 也 没有 类 型 检查 的 一 类 编程 语言 ) ， 所 以 在 使 用 变量 时 ， 
不 用 事先 指定 变量 类 型 ， 在 使 用 时 根据 上 下 文 由 系统 解释 器 来 判断 变量 的 类 型 。 另 外 ，PHP 也 不 像 其 
他 编程 语言 ， 要 先 定义 才能 使 用 ， 在 PHP 中 ， 变 量 不 用 事先 定义 即 可 使 用 。 


3.2.(1 PHP 的 变量 类 型 
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PHP 的 变量 类 型 有 以 下 儿 种 : 整 型 变量 (integer) 、 浮 点 型 变量 (double) 、 字 符 型 变量 (string) ~ 
数组 变量 (array) 和 对 象 型 变量 (object) 。 
整 型 变量 在 32 位 操作 系统 中 的 有 效 范围 是 -2147483648 一 +2147483647。 要 使 用 16 位 整数 可 
以 在 前 面 加 0x。 
浮 点 型 变量 在 32 位 操作 系统 中 的 有 效 范围 为 1.7E-308 一 1.7E+308。 
字符 型 变量 不 同 于 其 他 编程 语言 ， 有 字符 与 字符 串 之 分 ， 在 PHP 中 ， 统 一 使 用 字符 型 变量 来 
定义 字符 或 者 字符 串 。 
数组 变量 是 一 种 比较 特殊 的 变量 类 型 ， 将 在 3.4 节 中 详细 说 明 。 
对 象 变量 也 是 一 种 比较 特殊 的 变量 。 在 PHP 5 之 前 ，PHP 面向 对 象 编程 的 功能 还 不 是 很 强大 。 
PHP 5 改变 了 这 种 状况 。 类 概念 的 引入 ， 使 PHP 真正 成 为 一 种 面向 对 象 的 编程 语言 。 
定义 一 个 变量 的 方法 很 简单 ， 就 是 在 该 变量 名 前 加 上 美元 符号 “$”。 下 面 的 例子 就 分 别 定义 了 两 
个 整 型 变量 和 两 个 字符 型 变量 。 


<?php 
$int1=0; /定义 一 个 整 型 变量 ， 赋 值 为 0 
$int2=1253; /定义 一 个 整 型 变量 ， 赋 值 为 1253 
$string-"a"; /定义 一 个 字符 型 变量 ， 赋 值 为 a 
$string1-"I'm a teacher!"; /定义 一 个 字符 串 变 量 ， 赋 值 为 1m a teacher! 
?> 


注意 : 变量 在 使 用 时 也 需要 加 “$” 符 号 并 且 引 用 变量 时 注意 变量 名 的 大 小 写 。 
通过 以 上 例子 能 够 发 现 ， 在 PHP 中 定义 一 个 变量 是 一 件 很 简单 的 事情 。 
3.2.2 ”转换 变量 类 型 
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在 实际 使 用 PHP 的 过 程 中 , 有 时 需要 对 变量 的 类 型 进行 强制 转换 , 如 要 把 字符 型 变量 变 为 数值 型 、 
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网 络 编程 技术 详解 


把 数值 型 变量 变 为 字符 型 等 。 在 PHP 中 可 通过 settype0 函 数 来 设置 一 个 变量 的 类 型 。 其 使 用 方式 如 下 
所 示 : 

settype(mixed var,string type) 

作用 是 将 变量 var 的 类 型 设置 成 type。type 的 可 能 值 ( 即 能 够 转变 的 类 型 ) JJ boolean (ERJ bool, 
从 PHP 4.2.0 起 ) integer (ERX int, JÀ PHP 4.2.0 起 ) 、float (只 在 PHP 4.2.0 之 后 可 以 使 用 ， 旧 版 本 
中 使 用 的 double 现 已 停 用 ) ~ string, array, object, null (从 PHP 4.2.0 起 ) 。 如 果 类 型 转换 成 功 则 返 
回 True， 失 败 则 返回 False。 


注意 : 转化 类 型 时 ， 可 能 造成 数据 精度 损失 。 
【实例 3-4】 以 下 代码 演示 使 用 settype() 函 数 设 置 变 量 类 型 。 


01 <html> 

02 <head> 

03 ”<tile>settype() 函 数 使 用 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 S$foo-"5bar"; /定义 一 个 字符 串 变 量 

08 $bar=true; // 定 义 一 个 逻辑 值 变量 

09 echo $foo; // 输 出 变量 $foo 

10 echo "«p»"; /| 输 出 HTML 回 车 换行 

11 echo $bar; // 输 出 变量 $bar 

12 echo "«p»"; 

13 settype($foo,"integer"); /重新 设置 $foo 的 类 型 为 整 型 
14 settype($bar,"string"); /重新 设置 $bar 的 类 型 为 字符 型 
15 echo $foo; /重新 输出 $foo 

16 echo "«p»"; 

nite echo $bar; // 重 新 输出 $bar 

1892» 

19 </body> 

20 </html> 


保存 以 上 代码 为 3-4.php， 在 PHP 运行 环境 中 执行 以 上 代码 ， 其 执行 结果 如 图 3.4 所 示 。 


ejus 


图 3.4 ”settype() 函 数 使 用 实例 执行 结果 


在 使 用 settype0 函 数 前 ，$foo 变量 值 为 字符 串 、$bar 变量 值 为 逻辑 真 值 ， 所 以 打印 出 它们 的 值 为 
Sbar 和 1; 在 使 用 settype0 函 数 后 ，$foo 变量 值 改变 为 整 型 数 、$bar 变量 值 改变 为 字符 串 ， 所 以 打印 的 
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结果 为 5 和 1。 
3.2.3 ”变量 的 使 用 范围 
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和 其 他 编程 语言 一 样 ，PHP 中 的 变量 也 有 全 局 变量 与 局 部 变量 之 分 。 所 谓 全 局 变量 ， 指 在 程序 运 
行 期 间 都 能 使 用 的 变量 ， 而 局 部 变量 只 在 子 函数 或 过 程 中 有 效 。 在 PHP 程序 执行 时 ， 系 统 会 在 内 存 中 
保留 一 块 全 局 变量 的 区 域 。 实 际 运 用 时 ， 可 以 通过 $GLOBALS[" 变 量 名称 "] 的 方式 访问 。 不 过 需要 注意 
的 是 ，PHP 的 变量 有 大 小 写 之 分 ， 如 果 大 小 写 不 匹配 是 不 能 调 出 来 的 。 

SGLOBALS 数组 是 PHP 程序 中 比较 特殊 的 变量 , 不 必 事 先 声明 ,系统 会 自动 匹配 相关 的 变量 在 里 
面 ， 因 此 在 函数 中 可 以 直接 使 用 。 

和 $GLOBALS 变量 类 似 的 ， 还 有 $php_errormsg 字符 串 变量 。 若 PHP 的 配置 文件 php.ini 中 的 
track errors 选项 值 为 True， 使 用 全 局 变量 $php_errormsg 可 以 看 到 错误 的 信息 。 

在 PHP 中 ， 全 局 变量 的 有 效 范围 只 限于 主 程序 中 ， 不 会 影响 到 函数 中 同名 的 变量 ， 也 就 是 全 局 变 
量 与 局 部 变量 互 不 干扰 。 若 要 全 局 变量 也 能 在 子 函数 中 使 用 , 就 要 用 到 $GLOBALS 数组 或 是 使 用 globals 


宣告 。 


例如 ， 在 自行 开发 的 函数 中 ， 要 取得 目前 执行 PHP 文件 的 文件 名 ， 就 可 以 用 $GLOBALS 
["PHP_SELF"] 取 出 SPHP_SELF 的 值 。 


注意 : 要 合理 使 用 变量 ， 避 免 造 成 内 存 的 浪费 。 


3.3 PHP 的 预定 义 变量 


YA 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 3 章 \PHP 的 预定 义 变量 .wmv 
PHP 在 系统 中 内 置 了 大 量 与 系统 、 正 在 运行 的 PHP 文件 、HTTP 等 相关 的 变量 ， 如 表 32 所 示 。 
了 解 和 使 用 这 些 预定 义 变量 对 提高 编程 效率 有 很 大 帮助 。 本 节 将 介绍 一 些 常 用 的 PHP 预定 义 变量 ， 更 
多 的 变量 请 参考 phpinfo() 函 数 所 列 出 的 内 容 。 
表 3.2 PHP 中 的 预定 义 变量 


作 用 
当前 正在 执行 的 文件 名 。 返 回 值 与 document root 相关 
访问 页 面 时 的 请 求 方法 。 例 如 : GET、HEAD、POST、PUT 
当前 运行 脚本 所 在 的 文档 根 目录 。 在 APACHE 配置 文件 中 定义 
链接 到 当前 页 面 的 前 一 页 面 的 URL. 地 址 。 不 是 所 有 的 用 户 代理 (浏览 器 ) 都 会 
设置 这 个 变量 ， 而 且 有 的 还 可 以 手工 修改 HTTP REFERER。 因 此 ， 这 个 变量 
不 总 是 正确 、 真 实 的 
正在 浏览 当前 页 面 用 户 的 IP 地 址 
通过 HTTP COOKIES 传递 的 变量 组 成 的 数组 。 是 自动 全 局 变量 
通过 HTTP GET 方法 传递 的 变量 组 成 的 数组 。 是 自动 全 局 变量 
通过 HTTP POST 方法 传递 的 变量 组 成 的 数组 。 是 自动 全 局 变量 


LR 
$ SERVER[PHP SELF] 
$ SERVER[REQUEST METHOD] 
$ SERVER[DOCUMENT ROOT) 


$ SERVER[HTTP REFERER] 


$ SERVER[REMOTE ADDR] 
$ COOKIE 

$ GET 

$ POST 


(0 PHP 网 络 编程 技术 详解 


续 表 
a 称 ft 用 
$ FILES 通过 HTTP POST 方法 传递 的 已 上 传 文件 项 目 组 成 的 数组 。 是 自动 全 局 变量 


$ REQUEST | 此 关联 数组 包含 $ GET. $ POST ÄIS COOKIE 中 的 全 部 内 容 
$ SESSION 包含 当前 脚本 中 已 经 注册 的 SESSION 变量 的 数组 


SGLOBALS 由 所 有 已 定义 全 局 变量 组 成 的 数组 。 变 量 名 就 是 该 数组 的 索引 


3.4 PHP 中 的 数组 型 变量 


数组 型 变量 是 一 组 具有 名 称 的 变量 的 集合 ， 它 是 一 种 很 独特 的 变量 。PHP 中 的 数组 可 以 是 一 维 也 
可 以 是 多 维 的 ， 数 组 内 元 素 的 类 型 可 以 是 数字 、 字 符 甚至 是 数组 。 


3.4.1 数组 变量 的 初始 化 


GE 知识 点 讲解 : 光盘 \ 视 频 讲 解 \ 第 3 章 \ 数 组 变量 的 初始 化 .wmv 
在 PHP 中 初始 化 数组 一 般 有 两 种 方法 ， 一 种 是 同时 给 数组 中 所 有 元 素 赋值 ， 另 一 种 是 单独 给 数组 
每 个 元 素 赋值 。 下 面 通过 实例 来 具体 了 解 这 两 种 方法 。 
【实例 3-5】 以 下 代码 演示 同时 给 数组 所 有 元 素 赋值 。 
Um 实例 3.5， 同 时 给 数组 所 有 元 素 赋值 
| 源码 路 径 ， 光盘 \ 源 文件 \03\3-5.php 


01 «html» 

02 «head» 

03 ”<title> 同 时 给 数组 所 有 元 素 赋值 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 $string-array( 

08 "string", 

09 "string2", 

10 "string3", 

11 "string4", 

12 "string5" 

13 y /定义 一 个 数组 ， 同 时 给 数组 所 有 元 素 赋值 
14 for($i=0; $i<count($string);$i++) // 循 环 读 取 数 组 内 容 
15 { 

16 echo $string[$i]; /显示 数组 元 素 

17 echo "«br»"; /输出 HTML 换行 符 
18 ) 

19 ?> 

20 </body> 

21 «html» 


注意 : 数组 中 的 元 素 可 以 为 不 同 的 类 型 。 
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【实例 3-6】 以 下 代码 演示 单独 给 数组 每 个 元 素 赋值 。 


re 实例 3-6: 单独 给 数组 每 个 元 素 赋值 
源码 路 径 ， 光盘 \ 源 文件 \03\3-6.php 


01 <html> 

02 <head> 

O3 ”<title> 分 别 给 数组 每 个 元 素 赋值 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 $string[0]-"string1"; /定义 数组 ， 给 数组 每 个 元 素 单独 赋值 
08 $string[1]-"string2"; 

09 $string[2]-"string3"; 

10 $string[3]-"string4"; 

11 $string[4]-"string5"; 

12 for($i=0; $i<count($string);$i++) /| 循环 读 取 数 组 内 容 
13 € 

14 echo $string[Si]; // 显 示 数 组 元 素 

15 echo "<br>"; /| 输出 HTML 换行 符 
16 ) 

17 ?> 

18 </body> 

19 </html> 


在 PHP 运行 环境 中 分 别 执行 以 上 两 个 实例 中 代码 ， 输 出 的 结果 是 一 样 的 ， 如 图 3.5 所 示 。 不 同 的 
是 ， 实 例 3-5 是 同时 给 所 有 元 素 赋值 ， 而 实例 3-6 是 分 别 给 每 个 元 素 赋值 。 


[€] 2A B hitp://localhost/3- £ 


| stringi 
string? 
string3 
stringá 
stringó 


图 3.5 给 数组 赋值 实例 执行 结果 
3.4.2 ”获取 数组 中 的 元 素 


GEH 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 3 章 \ 获 取 数 组 中 的 元 素 .wmv 

给 一 个 数组 赋值 之 后 就 可 以 使 用 了 。 使 用 的 方法 也 很 简单 ， 只 需 使 用 数组 名 加 上 所 需要 的 元 素 的 
序号 即 可 。 需 要 注意 的 是 ， 以 数字 作为 下 标的 数组 中 下 标 值 是 从 0 开始 的 。 如 $String[2]， 就 实现 了 对 
数组 $String 第 3 个 元 素 的 引用 。 

【实例 3-7】 以 下 代码 演示 引用 数组 中 的 元 素 。 


Nc b 实例 3-7: 引用 数组 中 的 元 素 
源码 路 径 。 光 盘 \ 源 文件 03\.3-7 php 


01 «html» 
02 <head> 


KA aaa 


03 ”<title> 引 用 数组 元 素 实例 </title> 


04 </head> 
05 <body> 
06 <?php 
07 $string-array( 
08 "string", 
09 "string2", 
10 "string3", 
11 "string4", 
12 "string5" 
13 y /定义 一 个 数组 
14 echo "数组 的 第 三 个 元 素 为 :"; 
15 echo $string[2]; 1/ 获取 数组 第 三 个 元 素 
16 echo "<br>"; 
17 echo "数组 的 第 五 个 元 素 为 :"; 
18 echo $string[4]; /获取 数组 第 五 个 元 素 
19 echo "<br>"; 
20 echo "数组 的 第 一 个 元 素 为 : "; 
21 echo $string[0]; /获取 数组 第 一 个 元 素 
22 ?> 
23 </body> 
24 </html> 
在 PHP 运行 环境 下 执行 以 上 代码 ， 执 行 结果 如 图 3.6 所 示 。 
f ESI 


图 3.6 引用 数组 元 素 实例 执行 结果 
说 明 : 批量 获取 数组 的 元 素 ， 可 以 采用 循环 的 方式 。 内 容 会 在 后 面 讲解 。 


3.4.3 ”给 数组 动态 增加 元 素 


FÈ 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 3 章 \ 给 数组 动态 增加 元 素 .wmv 
一 个 数组 在 定义 后 ， 其 元 素 个 数 并 不 是 一 成 不 变 的 ， 程 序 在 运行 中 可 以 动态 地 为 数组 增加 元 素 。 
要 给 一 个 数组 动态 增加 元 素 ， 所 要 做 的 只 是 给 数组 新 的 元 素 赋值 。 
【实例 3-8】 以 下 代码 演示 动态 地 为 数组 增加 元 素 。 
区 < | 实例 3-8: 动态 地 为 数组 增加 元 素 
源码 路 径 光盘 \ 源 文件 \03\3-8.php 


02 <head> 

03 ”<title> 动 态 地 为 数组 增加 元 素 实例 </title> 
04 </head> 

05 <body> 

06 <?php 
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07 $string-array( 

08 "string1", 

09 "string2", 

10 "string3", 

11 "string4", 

12 "string5" 

13 y /定义 一 个 数组 

14 echo "数组 的 第 三 个 元 素 为 : "; 

15 echo $string[2]; /获取 数组 元 素 

16 echo "<br>"; 

17 echo "数组 的 第 五 个 元 素 为 : "; 

18 echo $string[4]; 

19 echo "<br>"; 

20 echo "数组 的 第 一 个 元 素 为 : "; 

21 echo $string[0]; 

22 echo "<br>"; 

23 $string[5]-"string6"; /为 数组 动态 增加 元 素 
24 $string[6]="string7"; // 为 数组 动态 增加 元 素 
25 echo "下 面 的 是 新 增加 的 数组 元 素 : <b"; 

26 echo "数组 的 第 六 个 元 素 为 :"; 

27 echo $string[5]; // 获 取 新 增加 的 元 素 
28 echo "<br>"; 

29 echo "数组 的 第 七 个 元 素 为 :"; 

30 echo $string[6]; 

gi Ya 

32 </body> 

33 </html> 


注意 : 通常 情况 下 不 要 无 限制 地 为 数组 增加 元 素 ， 这 样 会 导致 系统 运行 缓慢 。 
在 PHP 运行 环境 中 执行 以 上 代码 ， 执 行 结果 如 图 3.7 所 示 。 


ea 


图 3.7 动态 地 为 数组 增加 元 素 实例 执行 结果 
3.4.4 创建 多 维 数组 


Ga 知识 点 讲解 : 光盘 \ 视 频 讲 解 \ 第 3 章 \ 创 建 多 维 数 组 .wmv 

一 维 数组 的 格式 是 Array[]， 二 维 数 组 的 格式 是 Array[][], 多 维 数组 的 格式 是 Array[][]…[]。 和 一 维 
数组 一 样 ， 给 多 维 数组 赋值 也 有 两 种 方法 。 下 面 分 别 通过 实例 来 具体 说 明 。 

先 来 了 解 一 下 同时 给 多 维 数组 所 有 元 素 赋值 。 

【实例 3-9】 以 下 代码 演示 在 定义 多 维 数组 的 同时 为 数组 元 素 赋值 。 


8) 


(0 PHPRÉSREHAÉRE 


re 实例 3-9 
| 源码 路 径 ， 光 盘 \ 源 文件 03\3-9.php 


01 «html» 

02 «head» 

O3 ”<title> 同 时 给 多 维 数组 所 有 元 素 赋值 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 $string-array( 

08 0=>array( 

09 0, 

10 1, 

11 2 

12 ) 

13 1=>array( 

14 "string1", 

15 "string2", 

16 "string3", 

17 "string4", 

18 ) 

19 2-»array( 

20 "你 好 ! "， 

21 "大 家 好 ，"， 

22 " 才 是 真 的 好 " 

23 ) 

24 JE /创建 二 维 数组 ， 数 组 元 素 也 是 数组 
25 for($i=0; $i<count($string);$i++) 1/ 通过 循环 读 取 外 层 数组 内 容 
26 { 

27 for($j=0;$j<count($string[$1]); $j++) 1/ 通过 循环 读 取 内 层 数组 内 容 
28 

29 echo $string[Si][Sj]; /显示 数组 元 素 
30 echo ",^; 

31 ) 

32 echo "<br>"; 

33 ) 

34 ?> 

35 </body> 

36 </html> 


实例 3-10， 单 独 给 数组 每 个 元 素 赋值 
源码 路 径 ， 光 盘 \ 源 文件 03\3-10.php 
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01 <html> 

02 <head> 

03 ”<title> 单 独 给 多 维 数组 每 个 元 素 赋值 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 $string[0][0]-0; /| 单独 给 多 维 数 组 每 个 元 素 赋值 
08 S$string[0][1]71; 

09 $string[0][2]-2; 

10 $string[1][0]-"string1"; 

11 $string[1][1]-"string2"; 

12 $string[1][2]-"string3"; 

13 $string[1][3]-"string4"; 

14 $string[2][0]- "fk 37! "; 

15 $string[2][1]-" A 95, "; 

16 $string[2][2]=" 才 是 真 的 好 "; 

17 for($i=0;$i<count($string);$i++) // 通 过 循环 读 取 外 层 数组 内 容 


{ 
19 for($j=0;$j<count($string[$i]);$j++) // 通 过 循环 读 取 内 层 数组 内 容 
{ 
21 echo $string[$il[$j]; /显示 数组 元 素 
22 echo ","; 
23 ) 
24 echo "<br>"; 


27 </body> 
28 </html> 


在 PHP 运行 环境 中 执行 以 上 代码 ， 执 行 结 果 和 图 3.8 一 样 。 尽 管 以 上 两 例 数组 赋值 所 采用 的 方法 
不 同 ， 但 都 达到 了 给 多 维 数组 赋值 的 目的 。 


说 明 : 常用 的 多 维 数 组 通常 在 三 维 以 内 。 
355 本 章 小 结 


本 章 主要 介绍 了 PHP 中 的 常量 与 变量 ， 并 详细 说 明了 常量 的 定义 与 使 用 、PHP 中 的 预定 义 常量 ; 
变量 的 类 型 、 变 量 的 使 用 范围 、PHP 的 系统 变量 ， 数 组 变量 的 初始 化 、 获 取 数 组 中 的 元 素 、 给 数组 动 
态 增加 元 素 及 多 维 数组 的 创建 与 使 用 等 内 容 。 


3.6 本 章 习 题 


习题 3-1 编写 代码 : 定义 一 个 名 为 AGE 的 常量 ， 其 值 为 18。 
【分 析 】 该 习题 考查 读者 对 常量 定义 方式 的 掌握 。 


KA ea 


【关键 代码 】 

define("AGE",18); 

习题 3-2 编写 代码 : 输出 当前 运行 PHP 解释 器 的 操作 系统 。 
【分 析 】 该 习题 考查 读者 对 预定 义 常量 的 掌握 。 
【关键 代码 】 

echo PHP OS; 

习题 3-3 ”编写 代码 : 定义 一 个 变量 age 并 为 其 赋值 18， 然 后 输出 该 变量 的 值 。 
【分 析 】 该 习题 主要 考查 读者 对 变量 的 定义 和 使 用 的 掌握 情况 。 
【关键 代码 】 

$age=18; 

echo $age; 

习题 3-4 ”编写 代码 : 将 如 下 常量 存 入 一 个 名 为 arr 的 数组 变量 中 。 


hello 
你 好 
nihao 


【分 析 】 该 习题 主要 考查 读者 对 数组 初始 化 的 掌握 。 
【关键 代码 】 
Sarr-array('hello', 4" nihao"); 
习题 3-5 ”输出 如 下 数组 中 的 常量 5: 
$arr=array(array(1,2,3),array(6,5,4),array(7,9,8)); 


【分 析 】 该 习题 主要 考查 读者 对 数组 元 素 访问 的 掌握 。 
【关键 代码 】 


echo $arr[1][1]; 


第 4 章 PHP 中 的 运算 符 与 表达 式 


运算 符 与 表达 式 是 PHP 中 十 分 重要 的 概念 。 在 PHP 编程 中 ， 表 达 式 是 PHP 程序 最 重要 的 基石 ， 
而 运算 符 又 是 构成 表达 式 的 基础 。 可 以 说 任何 复杂 的 PHP 程序 都 是 由 最 基本 的 运算 符 和 表达 式 组 成 的 。 
熟练 运用 PHP 中 的 运算 符 与 表达 式 ， 是 进行 PHP 编程 的 基本 功 。 m PHP 中 的 运算 符 与 表 
达 式 。 通 过 本 章 的 学 习 ， 读 者 将 会 对 PHP 中 的 运算 符 与 表达 式 有 一 个 全 面 的 认识 


PHP 中 的 运算 符 分 为 四 则 运算 符 、 逻 辑 运算 符 、 三 目 运算 符 、 赋 值 运算 符 、 字 符 串 运算 符 等 。 本 
节 将 会 为 读者 详细 介绍 PHP 中 运算 符 的 相关 知识 。 


4.1.1 四 则 运算 符 


GA 知 识 点 讲解 : 光盘 \ 视 频 讲 解 \ 第 4 章 \ 四 则 运算 符 .wmv 
四 则 运算 符号 有 4 种 ， 包 括 “+” (加 ) 、“-” ( 减 ) 、“*” ( 乘 ) 、“/”【〔 除 ) 。 这 些 都 是 
人 们 非常 熟悉 的 符号 ，PHP 中 的 运算 符 基 本 与 此 类 似 ， 只 是 多 一 个 “%” 求 余数 的 运算 符 。 下 面 通过 
表 4.1 来 具体 介绍 。 
表 4.1 PHP 中 的 四 则 运算 符 


例子 结 m 
-$a $a 的 相反 数 
Sa*$b $a 和 $b 的 和 
$a-$b $a 和 $b 的 差 
Sa*$b Sa 和 S$b 的 积 
$a/$b Sa 和 $b 的 商 
$a%$b $a 除 以 $b 的 余数 


注意 : 在 使 用 “/” 符 号 时 ， 要 注意 求 得 的 商 必定 是 浮 点 数 ， 即 使 能 整除 也 是 这 样 。 
4.1.2 ”逻辑 运算 符 
GE 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 4 章 \ 远 辑 运 算 符 .wmv 


PHP 中 的 逻辑 运算 符 有 与 、 或 、 异 或 、 非 4 种 ， 其 中 的 逻辑 与 和 逻辑 或 有 两 种 表现 形式 ， 下 面具 
体 说 明 。 


0000 aaa 


and GEH 5): Sa and Sb 两 个 表达 式 求 与 。 只 有 当 两 个 表达 式 都 为 真 时 返回 True, FW 


[s 


False. 


or 


返 


OGER): Sa or $b 两 个 表达 式 求 或 。 当 两 个 表达 式 都 为 假 时 返回 False, FRE True. 


xor OZER): Sa xor $b 两 个 表达 式 求 异 或 。 当 两 个 表达 式 不 同时 为 真 时 返回 True, fill 


回 False。 


! OZE): !$a 一 个 表达 式 求 非 。 当 $a X False 时 返回 True， 反 之 返回 Falses 
&& OZ): 见 and。 
|| GZR): 见 or。 


说 明 : 之 所 


以 “与 ”与 “或 ”有 两 种 表现 形式 GZK: and. &&; BHAR: or |), AAA CM 


运算 优先 级 不 同 ， 这 一 点 将 在 运算 符 的 优先 级 一 节 ( 4.1.4 小 节 ) 详细 说 明 。 
【实例 


4-1】 以 下 代码 演示 逻辑 运算 符 的 使 用 方法 。 


02 <head> 

03 ”<title> 逻 辑 运算 符 使 用 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 $a-TRUE; /定义 逻辑 变量 真 
08 $b=FALSE; /定义 逻辑 变量 假 
09 if($a and $b) 

10 echo "这 里 为 假 1! "; // 求 与 
11 echo "«br»"; 

12 if($a or $b) 

13 echo "这 里 为 真 1! "; // 求 或 
14 echo "<br>"; 

15 if($a xor $b) 

16 echo "这 里 为 真 2!"; // 求 异 或 
17 echo "<br>"; 

18 if(!$a) 

19 echo "这 里 为 假 2"; // 求 非 
20 ?» 

21 </body> 

22 </html> 


在 PHP 运行 环境 中 执行 以 上 代码 ， 执 行 结果 如 图 4.1 Bras 


图 4.1 逻辑 运算 符 使 用 实例 执行 结果 
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从 图 中 可 以 发 现 ， 以 上 代码 中 只 有 两 名 echo 语句 成 功 运行 了 。 下 面 分 析 一 下 以 上 程序 4 个 项 目的 
运行 过 程 : 

第 一 个 判断 对 一 真一 假 两 项 求 与 。 因 两 者 不 同时 为 真 ， 所 以 返回 “ 假 ”。 

第 二 个 判断 对 一 真一 假 两 项 求 或 。 因 二 者 有 一 个 为 真 ， 所 以 返回 “ 真 ”。 

第 三 个 判断 对 一 真一 假 两 项 求 异 或 。 因 两 者 状态 不 同 ， 所 以 返回 “ 真 ”。 

第 四 个 判断 对 一 个 真 值 求 非 ， 所 以 返回 “ 假 ”。 

下 面 把 以 上 代码 做 如 下 改动 : 

这 $a and $b) 改 为 这 !($a and $b)， 把 这 !$a) 改 为 这 !$b)。 然 后 再 执行 以 上 代码 ， 执 行 结果 如 图 4.2 所 示 。 


图 42 逻辑 运算 符 使 用 实例 执行 结果 
从 以 上 实例 及 改动 后 的 执行 情况 ， 可 以 认识 到 这 些 罗 辑 运算 符 是 如 何 起 作用 的 。 


4.1.3 三 目 运 算 符 


(E 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 4 章 \ 三 目 运算 符 .wmv 
和 C 语言 一 样 ，PHP 中 也 有 三 目 运 算 符 “?:”。 它 的 运行 机 制 如 下 所 示 : 
(expr1)?(expr2):(expr3) 
其 中 的 exprl、expr2 及 expr3 均 为 表达 式 。 当 表达 式 exprl 为 真 时 则 执行 后 边 的 expr2， 反 之 则 执 
行 expr3。 
说 明 : 从 分 析 中 不 难看 出 ， 三 目 运算 符 “?:” 实 际 上 也 就 是 证 ..else 的 简化 版 。 
【实例 4-2】 以 下 代码 演示 三 目 运算 符 的 使 用 方法 。 


02 <head> 


04 </head> 


07 $date-Date("D"); // 把 当前 星期 赋值 给 变量 
08 (($date=="Sun")or($date=="Sat"))?($s=" 周 末 "):($s=" 工 作 "); 1/ 判断 是 否 是 周末 

09 echo $s; // 显 示 状 态 

10 ?» 

11 </body> 

12 </html> 


在 PHP 运行 环境 下 执行 以 上 代码 ， 如 果 当 前 日 期 的 星期 为 周 六 或 周 日 时 显示 “休息 ”， 和 否则 显示 


@ 
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“工作 ”。 通 过 这 个 实例 可 以 认识 到 三 目 运算 符 的 使 用 方法 。 
44.4 运算 符 的 优先 级 
(9 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 4 章 \ 运 算 符 的 优先 级 .wmv 


TE PHP 中 除了 前 几 小 节 讲 到 的 常用 运算 符 之 外 ， 还 有 其 他 的 一 些 运算 符 ， 那 么 这 么 多 的 运算 符 ， 
它们 的 优先 级 〈 也 就 是 先 执行 ， 后 执行 的 问题 ) 情况 是 怎么 样 呢 ? 表 4.2 列 出 了 PHP 中 的 运算 符 ， 并 


按 顺序 给 出 了 它们 的 优先 级 。 
表 4.2 PHP 中 运算 符 的 优先 级 
结合 方向 运 算 符 附加 信息 
非 结 合 new new 
左 [ array() 
非 结 合 H= 递增 /递减 运算 符 
非 结合 1 ~- (int) (float) (string) (array) (object) @ 类 型 
左 */% 算术 运算 符 
左 tai 算术 运算 符 和 字符 串 运 算 符 
左 << >> 位 运算 符 
上 E 结 合 <<>> 比较 运算 符 
TT — EIE 比较 运算 符 
左 & 位 运算 符 和 引用 
左 ^ 位 运算 符 
左 位 运算 符 
左 && 逻辑 运算 符 
左 逻辑 运算 符 
左 ?: 三 目 运算 符 
右 =+ cede Re ^- >= 赋值 运算 符 
左 and 逻辑 运算 符 
左 xor 逻辑 运算 符 
za or 逻辑 运算 符 


技巧 : 在 编程 过 程 中 可 以 使 用 小 括号 改变 运算 顺序 。 

左 结合 表示 表达 式 从 左 向 右 求 值 ， 右 结合 则 相反 。 从 表 4.2 中 可 以 发 现 PHP 中 的 运算 符 有 严格 的 
运算 优先 级 。 只 有 搞 清楚 它们 的 优先 级 ， 才 能 正确 得 出 由 运算 符 构 成 的 表达 式 的 值 。 

【实例 4-3】 以 下 代码 演示 PHP 中 运算 符 的 优先 级 在 实际 中 的 运用 。 


re 实例 4-3: PHP 中 运算 符 的 优先 级 在 实际 中 的 运用 
源码 路 径 光盘 \ 源 文件 \04\4-3.php 


01 <html> 

02 <head> 

03 ”<title>PHP 运算 符 优先 级 使 用 实例 </title> 
04 </head> 
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05 <body> 

06 <?php 

07 $a=3*4+5%2; BAI 
08 echo $a."<br>"; 

09 $a -true?0:true?1:2; IA 2 
10 echo $a."<br>"; 

11 $a-1; 

12 $b-2; 

13 $a--$b*-3'$b*$a; // 语 句 3 
14 echo $a.",".$b."<br>"; 

15 7> 

16 </body> 

17 </html> 


在 PHP 运行 环境 中 执行 以 上 代码 ， 执 行 结果 如 图 4.3 所 示 。 

以 上 结果 是 怎么 得 出 的 ? 不 管 多 么 复杂 的 表达 式 ， 只 要 按 优先 级 把 它 分 解 为 简单 的 表达 式 ， 然 后 
就 可 以 分 析 其 结果 了 。 下 面 对 以 上 三 个 语句 进行 逐一 分 解 。 

语句 1 相对 简单 ， 只 用 分 解 为 (3*4)+(5%2) 即 可 。3*4 等 于 12, 5 除 以 2 余数 为 1。 所 以 就 是 12+1 
等 于 13。 

语句 2 稍微 复杂 一 点 ， 可 以 分 为 两 个 三 目 运算 符 : (true?0:true)?1:2=2。 第 一 个 三 目 运算 符 执行 后 
前 面 括号 内 容 为 0， 而 0 相当 于 False， 所 以 执行 第 二 个 三 目 运算 符 第 二 个 表达 式 。 所 以 就 有 $a 等 于 2。 

语句 3 就 有 点 复杂 了 。$a-=$b+=3*$b+$a 分 解 过 的 式 子 等 价 于 这 样 一 组 表达 式 : $b*3 等 于 6，6+$a 
等 于 7，$b+7 等 于 9，$b=9，$a-9 等 于 -8，$a=-8。 通 过 分 解 可 以 发 现 输出 的 结果 最 后 $a=-8、$b=9 是 
正确 。 其 执行 过 程 如 图 4.4 所 示 。 
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em 
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T 
$b= 9 


$a--8 
图 4.3 PHP 运算 符 优先 级 使 用 实例 执行 结果 图 4.4 语句 3 执行 过 程 图 
通过 上 面 的 实例 ， 发 现 只 有 掌握 了 PHP 运算 符 的 优先 级 ， 才 能 把 复杂 的 表达 式 转化 为 简单 的 表达 
式 ， 从 而 得 出 表达 式 正 确 的 结果 。 
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表达 式 是 PHP 的 基石 , 在 PHP 程序 中 , 几乎 所 写 的 东西 都 是 一 个 表达 式 。 何 为 表达 式 ? 简单 地 说 ， 
表达 式 就 是 “任何 有 值 的 东西 ”。 表 达 式 可 以 为 常量 、 变 量 或 者 函数 。 其 中 常量 和 变量 是 最 基本 的 表 
达 式 形式 ， 函 数 是 稍微 复杂 一 点 的 表达 式 形式 。 

例如 下 面 的 函数 : 


a) 


Ne pega 


<?php 
function foo() 
{ 
return 5; 
l 
?> 


那么 输入 Sc=foo0) 就 相当 于 写 下 Sc=5。 函 数 也 是 表达 式 ， 表 达 式 的 值 即 为 它们 的 返回 值 。 
4.2.1 表达 式 中 变量 的 可 能 


做 1 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 4 章 \ 表 达 式 中 变量 的 可 能 值 .wmv 

表达 式 赋值 给 一 个 变量 ， 其 中 的 值 可 能 有 4 种 标量 值 (标量 值 不 能 拆 分 为 更 小 的 单元 ， 和 数组 、 
对 象 不 同 ) 类 型 : 整 型 值 (integer) 、 浮 点 数值 (float) 、 字 符 串 值 (string) 和 布尔 值 (boolean) , 
还 包括 两 种 复合 类 型 (数组 和 对 象 ) 。 


说 明 : 表达 式 的 可 能 值 为 PHP 中 所 有 的 变量 类 型 。 


4.2.2 ”赋值 表达 式 的 值 


GÈ 知 识 点 讲解 : 光盘 \ 视 频 讲 解 \ 第 4 章 \ 赋 值 表达 式 的 值 .wmv 

一 个 赋值 表达 式 通 常 涉及 两 个 值 ， 如 $a=3 这 样 一 个 表达 式 涉及 整 型 常量 3 的 值 以 及 变量 $a 的 值 ， 
它 也 被 更 新 为 3: 还 有 一 个 即 赋值 语句 本 身 的 值 ， 赋 值 语句 本 身 的 值 为 被 赋 的 值 即 为 3。 因 而 ， 
“$b=($a=3)” 和 “$a=3;$b=3;” 是 一 样 的。 因为 赋值 操作 的 结合 顺序 是 由 右 到 左 的 ， 也 可 以 写 为 
“$b=$a=3”。 


注意 : 赋值 表达 式 涉及 3 个 值 ; 赋值 变量 值 、 被 赋 的 常量 值 及 表达 式 自身 的 值 。 
4.2.3 BERAR 


YA 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 4 章 \ 递 增 表 达 式 .wmv 

递增 〈 减 ) 表达 式 是 一 种 比较 特殊 的 表达 式 ， 这 类 表达 式 是 一 个 很 好 的 面向 表达 式 的 例子 。 该 类 
表达 式 有 前 、 后 递增 和 递减 。 从 本 质 上 来 讲 ， 前 递增 和 后 递增 均 增加 了 变量 的 值 ， 并 且 对 于 变量 的 影 
响 是 相同 的 。 不 同 的 是 递增 表达 式 的 值 。 前 递增 写 做 “++$variable”， 整 个 表达 式 的 值 为 增加 后 的 值 。 
后 递增 写 做 “$variablet++”， 整 个 表达 式 的 值 为 未 递增 之 前 的 值 。 

【实例 4-4】 以 下 代码 演示 前 递增 和 后 递增 表达 式 的 不 同 。 


TE —C 实例 4.4: 前 递增 和 后 递增 表达 式 的 丰 000000000 
源码 路 径 ， 光盘 源 文件 04\4-4.php 


02 <head> 

03 ”<title>PHP 运算 符 优先 级 使 用 实例 </title> 
04 </head> 

05 <body> 

06 <?php 


s48 PHPOduSusREX h 


07 $a=3; 

08 echo "$a-3&nbsp;&nbsp;"; 

09 echo "$a 为 : " 

10 echo **$a; II$a 前 递增 
11 echo "<p>"; 

12 $a-3; //$a 重新 赋值 为 3 
13 echo "$a-3&nbsp;&nbsp;"; 

14 echo "\$a++ 为 : "; 

15 echo $att; //$a 后 递增 
16 ?> 

17 </body> 

18 </html> 


技巧 : 前 递增 的 运算 规则 可 以 记 为 先 运算 后 取 值 ; 后 递增 则 可 以 记 为 先 取 值 后 运算 。 
在 PHP 运行 环境 下 执行 该 PHP 文件， 其 执行 结果 如 图 4.5 所 示 。 


图 4.5 递增 表达 式 执行 结果 
从 图 4.5 执行 结果 可 以 发 现 前 递增 表达 式 与 后 递增 表达 式 的 值 的 区 别 。 


424 ”比较 表达 式 


GE 知识 点 讲解 :光盘 \ 视 频 讲 解 \ 第 4 章 \ 比 较 表达 式 .wmv 

一 个 常用 的 表达 式 类 型 是 比较 表达 式 。 这 些 表达 式 的 值 为 False 或 True. PHP 支持 > (大 于 ) 、>= 
(大 于 等 于 ) 、 二 (等 于 ) 、(= (不 等 于 ) 、< (小 于 ) 、<= (小 于 等 于 ) 。PHP 还 支持 全 等 运算 符 
= 一 〈 值 和 类 型 均 相 同 ) 和 非 全 等 运算 符 !-= 〈 值 或 者 类 型 不 同 ) 。 
说 明 : 这 些 比 较 表达 式 最 常用 在 条 件 判 断 语句 ( 如 if 语 句 ) 中 ， 通 常 被 当 作 条 件 判断 语句 的 判断 条 件 。 

如 变量 $a 的 值 为 3， 变量 $b 的 值 为 4。 则 表达 式 $a< (小 于 ) Sb 的 值 就 为 真 。 因 为 3 本 来 就 小 于 4。 
反之 $a> (大 于 ) $b 的 值 就 为 假 。 


4.2.5 组 合 的 运算 赋值 表达 式 


YA 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 4 章 \ 组 合 的 运算 赋值 表达 式 .wmv 
通过 前 面 对 PHP 表达 式 的 介绍 ， 读 者 知道 如 果 想 要 为 变量 $a 加 1， 可 以 简单 地 写 “$a++” 或 者 
“++$a”。 但 是 如 果 想 为 变量 增加 大 于 1 的 值 如 3， 其 做 法 是 “$a=$at3”。“S$a+3” 计 算 $a 加 上 3 的 
值 ， 并 且 将 得 到 的 值 重 新 赋予 变量 8a， 于 是 $a 的 值 增 加 了 3。 
技巧 : 这 个 式 子 还 可 以 用 一 种 更 加 简短 的 形式 来 完成 : “$a+=3”。 这 里 的 意思 是 “ 取 变 量 $a 的 值 加 3， 
得 到 的 结果 再 次 赋值 给 变量 Sa”。 除 了 更 加 简略 之 外 ， 也 可 以 更 快 地 运行 。 


8) 
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“$a+=3” 的 值 ， 如 同一 个 正常 赋值 操作 的 值 ， 是 赋值 后 的 值 。 注 意 它 不 是 3， 而 是 $a 的 值 加 上 3 
后 的 值 (此 值 将 被 赋 给 ga) 。 任 何 二 元 运算 符 都 可 以 用 运算 赋值 模式 ， 例 如 ，“$a-=5” (从 变量 $a 
的 值 中 减 去 5) ，“$b*=7” (变量 $b 乘 以 7) 等 。 


4.3 运算 符 与 表达 式 综合 运用 实例 


GE 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 4 章 \ 运 算 符 与 表达 式 综合 运用 实例 .wmv 

前 面 两 节 介绍 了 PHP 中 的 运算 符 与 表达 式 的 相关 知识 。 本 节 将 通过 综合 的 实例 来 系统 地 巩固 前 两 
节 所 讲 内 容 。 

【实例 4-5】 以 下 代码 演示 一 个 运算 符 与 表达 式 综合 运用 的 实例 。 


01 <html> 

02 <head> 

03 ”<title>PHP 运算 符 与 表达 式 综合 运用 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 $a-"123"; 

08 $b=321; 

09 echo $a+$b; // 字 符 当 数 字 用 
10 echo "<br>"; 

11 echo $a.$b; /数字 当 字符 用 
12 echo "«br»"; 

13 $a-123; 

14 $b=321; 

15 echo $b»$a; /比较 大 小 

16 echo "<br>"; 

17 echo $a-23+$b+=$a%3?50:30; // 三 目 运算 符 、 赋 值 运算 符 及 四 则 运算 符 
18 echo "<br>"; 

19 $a=123; 

20 $b-321; 

21 $a-$b; // 赋 值 表达 式 
22 echo $a==$b; 

23 echo "<br>"; 

24 ?> 

25 </body> 

26 </html> 


注意 : 实例 4-5 中 的 “$at$b” 实 现 了 把 数字 字符 当 作 数 字 来 使 用 。“$a.$b” 则 是 将 数字 当 字 符 用 。 

在 PHP 运行 环境 中 执行 以 上 代码 ， 其 执行 结果 如 图 4.6 所 示 。 

实例 4-5 中 的 “$a+Sb” 实 现 了 把 数字 字符 当 作 数字 来 使 用 ， 两 数字 相 加 值 为 444。“$a.Sb” 则 实 
现 了 把 数字 当 字 符 用 ， 两 字符 相 加 为 123321。 关 键 就 在 于 使 用 什么 运算 符 ， 如 果 用 “+”， 就 把 字符 


e. 


当 数字 ; 如 果 用 “.”， 就 把 数字 当 字 符 。 
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图 4.6 ”PHP 运算 符 与 表达 式 综合 运用 实例 执行 结果 
“$a>$b” 是 实现 对 两 个 数字 比较 大 小 。 因 为 321 大 于 123， 所 以 返回 真 值 即 1。 
$a-23+$b+=$a%3?50:30 是 三 目 运 算 符 、 赋 值 运算 符 及 四 则 运算 符 的 混合 使 用 。 因 为 数学 运算 符 遵 
循 从 右 到 左 的 标准 ， 而 三 目 运 算 符 则 是 从 左 向 右 ， 所 以 这 个 表达 式 可 以 分 为 以 下 儿 个 子 过 程 ，$a%3 值 
为 0， 执 行 三 目 运 算 符 “:” 后 的 内 容 ， 返 回 30，S$b=$b+30 等 于 351，$a-23=100，100+351=451。 
第 19—22 行 先 定义 两 个 不 同 的 变量 , 再 通过 赋值 操作 把 变量 $b 的 值 赋 给 变量 $a, 然后 判断 二 者 是 
否 相 等 ， 在 经 过 赋值 操作 后 ， 二 者 的 值 当然 相等 ， 所 以 比较 结果 返回 真 值 即 1。 
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本 章 主要 学 习 了 PHP 中 的 运算 符 与 表达 式 ， 包 括 PHP 的 四 则 运算 符 、 风 辑 运算 符 、 三 目 运 算 符 、 
运算 符 的 优先 级 以 及 PHP 中 的 表达 式 ， 它 们 的 重要 性 不 言 而 喻 ， 正 如 本 章 开头 所 介绍 的 那样 ， 运 算 符 
与 表达 式 是 PHP 最 重要 的 基石 。 


4.5 本 章 习 题 


习题 4-1 以 下 代码 的 运行 结果 是 : . 


«?php 
$a-5; 
$b=13; 
$c-9; 
echo $c*$b96$a; 


?> 


【分 析 】 该 习题 主要 考查 读者 对 “%” 运 算 符 和 运算 符 优先 级 的 掌握 情况 。 因 为 “%” 运 算 符 的 优 
先 级 要 高 于 “+” 运 算 符 ， 因 此 先 计算 “$b%$a”， 输 出 结果 应 该 为 12 “$b%$a” 的 值 为 3〉。 
习题 4-2 ”以 下 代码 的 运行 结果 是 : 
<?php 
$a=6; 
$b=7; 
$c-8; 
echo $a»$b?$a*$b:$a*$c; 
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【分 析 】 该 习题 主要 考查 读者 对 三 目 运算 符 的 掌握 。 由 于 “$a>$b ”不 成 立即 为 False, 因此 “$a+$c” 
会 被 运行 ， 那 么 结果 就 为 14。 
习题 4-3 ”以 下 代码 的 运行 结果 是 : 


$b-7; 
echo $a++ + ++$b; 
?» 


【分 析 】 该 习题 主要 考查 读者 对 前 、 后 递增 的 理解 。“$at+” 的 值 为 6， 而 “$b++” 的 值 为 8， 因 
此 结果 为 14。 
习题 4-4 以 下 代码 的 运行 结果 是 : 


echo ($al=$b)>($a>$b); 
?> 


【分 析 】 该 习题 主要 考查 读者 对 比较 表达 式 的 掌握 。“S$al=$b” 的 值 为 True (1) ， 而 “$a>$b” 
的 值 为 False (0) ， 因 此 结果 就 为 “1>0” 作 为 输出 即 为 1。 
习题 4-5 以 下 代码 的 运行 结果 是 : ° 
<?php 
$a=6; 
$b=7; 
echo $a.=$b; 
?» 


【分 析 】 该 习题 考查 读者 对 组 合 赋值 表达 式 的 掌握 。 这 里 “.=” 运 算 符 将 6 和 7 作为 字符 来 处 理 ， 
因此 结果 为 67。 


第 5 章 PHP 中 的 流程 控制 


无 论 在 何 种 编程 语言 中 ， 流 程控 制 都 是 很 重要 的 内 容 。 由 于 PHP 的 大 部 分 语法 都 继承 了 C 语言 的 
特点 ， 因 此 在 流程 控制 方面 ，PHP 有 着 和 C 语言 类 似 的 流程 控制 。 本 章 将 介绍 PHP 中 的 判断 与 循环 流 
程控 制 ， 主 要 包括 if.else 判断 、switch...case 多 重 判断 、while 循环 、do.…while 循环 、for 循环 等 。 


5.1] if.else 判断 


if..else 判断 ， 是 流程 控制 中 判断 执行 的 一 种 。 该 语句 执行 时 先 对 某 条 件 进行 判断 ， 然 后 根据 判断 
结果 做 出 相应 的 操作 。 它 又 可 以 细 分 为 3 种 : 简单 的 让 判 断 、if..else 判断 、f..else if...else 判断 。 本 节 
就 来 为 读者 具体 讲解 f...else 判断 。 


5.1.1 H if FIE 
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i£ 判断 是 流程 控制 中 最 简单 的 一 种 。 只 判断 某 条 件 是 否 为 真 ， 如 果 为 真 就 执行 特定 的 语句 。 就 像 
下 面 这 种 情况 : 

if(expr) 


statement 


) 

如 果 执行 的 statement GEA) 多 于 一 句 ， 就 要 使 用 “{}” 把 它们 括 起 来 ， 表 示 一 个 区 段 。 如 果 要 
执行 的 语句 只 有 一 句 ， 就 可 以 省 略 大 括号 标记 。 
技巧 : 执行 的 statement ( 语句 ) 为 一 句 时 也 可 以 使 用 “{}” 括 起 来 ， 这 样 可 以 方便 以 后 扩展 。 

【实例 5-1】 以 下 代码 演示 如 何 使 用 让 判断 。 


E og —O 实例 5-1; 如 何 使 用 计 判 断 
源码 路 径 : 光盘 \ 源 文件 \05\5-1.php 


02 <head> 

03 ”<title>if 判断 使 用 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 if($cost» 100) /如果 商品 的 价格 超过 100 元 执行 操作 
08 echo "EST, AE!" 
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09 ?> 

10 </body> 

11 </html> 

在 PHP 运行 环境 中 执行 以 上 语句 。 执 行 结 果 是 什么 ? 什么 也 没 发 生 。 这 是 因为 并 没有 定义 变量 
$cost， 没 有 定义 的 变量 就 是 空 值 ， 作 为 数值 就 是 “0”。 而 “0” 是 小 于 100 的 ， 这 明显 不 符合 让 后 面 
的 判断 内 容 〈$cost>100) ， 所 以 就 什么 也 不 执行 。 这 里 在 计 判 断 之 前 加 入 这 样 一 句 : 

$cost=101; 


再 执行 以 上 代码 。 执 行 结果 将 会 如 图 5.1 所 示 。 


图 5.1 让 判断 使 用 实例 执行 结果 


由 于 此 时 满足 8cost>100 的 条 件 ， 所 以 if 后 面 的 内 容 会 被 正确 执行 。 从 这 个 例子 中 能 够 认识 到 if 
判断 语句 是 如 何 运 行 的 。 


5.1.2 if..else 判断 
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这 判断 只 对 判断 结果 为 真 的 情况 执行 操作 ， 这 在 很 多 情况 下 是 不 够 的 ， 于 是 就 有 了 if..else 这 种 形 
式 的 判断 。 与 让 判断 不 同 ， 让 ..else 不 仅 对 判断 结果 为 真 的 情况 执行 操作 ， 对 非 真 的 情况 也 执行 相应 的 
操作 。 

为 了 简单 说 明 问题 ， 继 续 使 用 实例 5-1， 只 是 把 例子 做 简单 的 修改 。 

【实例 5-2】 以 下 代码 演示 if...else 判断 的 使 用 方法 。 


02 «head» 

03 <title>if...else 判断 使 用 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 $cost-101; 

08 if($cost» 100) // 如 果 商 品 的 价格 超过 100 元 执行 操作 
09 echo "KAT, RE!" 

10 else 

11 echo "还 挺 便宜 的 ， 就 买 它 吧 ! "; // 如 果 价 格 不 超过 100 元 的 操作 
ii irea 

13 </body> 

14 </html> 


技巧 : 同样 可 以 将 else 从 和 句 后 的 语句 使 用 “{}” 括 起 来 。 
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在 PHP 运行 环境 下 执行 以 上 代码 ， 执 行 结果 和 图 5.1 是 完全 一 样 的 。 因 为 $cost 的 值 大 于 100， 所 
以 让 语句 结果 为 真 ， 跟 在 后 面 的 echo 语句 就 执行 了 ， 即 显示 出 不 买 的 信息 。 
把 以 上 实例 中 的 

$cost=101; 

改 为 : 

$cost=99; 

重新 执行 以 上 代码 ， 执 行 结果 如 图 5.2 所 示 。 

Ooa 
图 5.2 if..else 判断 使 用 实例 执行 结果 


因为 ， 经 过 将 $cost 改 为 小 于 100 的 值 ， 计 语句 不 再 起 作用 ， 而 else 语句 则 起 了 作用 。 所 以 就 会 打 
印 出 购买 商品 的 信息 。 


技巧 : 使 用 让 ..else 谋 套 可 以 构成 更 复杂 的 功能 。 


5.1.3 if..else if...else 多 重 判 断 
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虽然 if..else 的 判断 比 单纯 的 站 语 句 多 了 一 重 判断 , 但 现实 情况 可 能 还 要 复杂 ， 要 判断 的 情况 会 超 
过 两 种 。 如 判断 学 生成 绩 ， 不 能 只 判断 及 格 或 不 及 格 ， 而 要 判断 优 、 良 、 中 、 差 。 不 管 是 简单 的 站 判 
断 ， 还 是 if..else 判断 都 已 经 不 能 胜任 了 ， 这 时 就 要 用 到 if..else if...else 的 多 重 判断 。 

if...else if...else 多 重 判断 的 使 用 方法 如 下 所 示 : 


if(expr) 
{ 
statement 
else if(expr) 
{ 


statement 
出 


else if(expr) 
ii 
statement 


statement 


注意 : 这 类 的 else 从 句 可 以 省 略 。 
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它 的 运行 机 制 是 : 先进 行 一 次 判断 ， 如 果 为 真 就 执行 语句 并 跳出 ;否则 再 进行 后 续 的 判断 ， 直 到 


判断 条 件 为 真 后 跳出 。 
【实例 5-3】 以 下 代码 演示 使 用 让 ..else if..else 多 重 判 断 来 根据 学 生 的 成 绩 判断 其 成 绩优 、 良 、 中 、 
差 的 级 别 。 


re 实例 5-3: 使 用 让 ..else if...else 多 重 判断 来 根据 学 生 的 成 绩 判断 其 成 绩优 、 良 、 差 的 级 别 
源码 路 径 光盘 \ 源 文件 \05\5-3.php 


02 <head> 

03 ”<title>if...else if...else 多 重 判断 使 用 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 $score-99; 

08 if($mark»90) // 如 果 成 绩 大 于 90 分 执行 操作 
09 echo "成 绩 级 别 为 : UL! "s 

10 else if($score >70) // 如 果 成 绩 在 70 一 90 间 执 行 操作 
11 echo "成 绩 级 别 为 ， 良 !"; 

12 else if($score >60) // 如 果 成 绩 在 60—70 间 执 行 操作 
13 echo "成 绩 级 别 为 ， 中 "; 

14 else // 如 果 成 绩 低 于 60 分 执行 操作 
15 echo "成 绩 级 别 为 ， 差 !"; 


在 PHP 运行 环境 中 执行 该 文件 。 通 过 改变 $score 的 值 为 大 于 90 时 返回 “ 优 ”， 当 值 在 70 一 90 fü] 
时 返回 “ 良 ”， 当 值 在 60 一 70 间 时 返回 “中 ”， 当 值 在 60 以 下 时 返回 “ 差 ”。 通 过 该 例子 ， 能 够 清 
楚 地 认识 到 if...else if...else 多 重 判断 是 如 何 运行 的 。 


5.2 switch..case 多 重 判断 
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多 重 判断 除了 if..else if...else 之 外 ， 还 有 另外 一 种 就 是 switch...case。 与 f..else if...else 多重 判断 相 
比较 ，switch...case 更 简洁 明了 。switch...case 多 重 判断 的 运行 机 制 如 下 所 示 : 


switch (expr) ( 
case expr1: 
statement; 
break; 
case expr2: 
statement2; 
break; 


e. 
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注意 : 这 里 的 default 从 身 可 以 省 略 。 


expr 通常 为 变量 名 称 ，case 后 的 exprN 通常 为 变量 的 值 ，statementN 为 符合 该 值 时 执行 的 语句 。 
default 为 除 以 上 所 有 判断 之 外 的 情况 ， 最 后 使 用 break 跳出 过 程 。 
【实例 5-4】 以 下 代码 演示 switch...case 多 重 判断 的 使 用 方法 。 


re 实例 5-4: switch...case 多 重 判断 的 使 用 方法 
源码 路 径 : 光盘 \ 源 文件 \05\5-4.php 


01 «html» 

02 <head> 

03 ”<title>switch...case 多 重 判断 使 用 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 switch (date("D")){ // 当 前 星期 作为 判断 条 件 
08 case "Mon": /星期 一 的 情况 
09 echo "星期 一 "; 

10 break; 

11 case "Tue": /星期 二 的 情况 
12 echo "星期 二 "; 

13 break; 

14 case "Wed": /星期 三 的 情况 
15 echo "星期 三 "; 

16 break; 

17 case "Thu": // 星 期 四 的 情况 
18 echo "星期 四 "; 

19 break; 

20 case "Fri": /星期 五 的 情况 
21 echo "星期 五 "; 

22 break; 

23 default: // 除 以 上 之 外 的 其 他 情况 
24 echo "过 周末 "; 

25 break; 

26 ) 

2r ve 

28 </body> 

29 </html> 


在 PHP 运行 环境 下 执行 ， 就 会 返回 中 文 的 星期 。 这 个 例子 如 果 用 让 判断 来 实现 就 会 比较 复杂 。 从 
这 个 例子 也 能 够 看 出 让 判断 与 switch...case 多 重 判断 的 不 同 。 

在 使 用 switch...case 语句 的 时 候 , 要 把 出 现 几率 大 的 情况 放 到 最 前 边 , 这 样 可 以 提高 程序 执行 效率 。 
因为 进行 完 一 次 判断 ， 如 果 符 合 条 件 ， 则 执行 完 相 关 语 句 就 跳出 整个 过 程 了 。 但 是 如 果 把 出 现 几率 大 
的 情况 放 到 最 后 ， 要 想 情况 出 现 ， 就 得 执行 完 所 有 判断 ， 这 样 效率 就 低 得 多 了 。 
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5.3 while 循环 


前 两 节 介 绍 了 PHP 流程 控制 中 的 判断 ， 从 这 节 开 始 为 读者 介绍 循环 。 循环 也 是 很 重要 的 一 类 流程 
控制 ， 通 过 循环 执行 某 些 特定 语句 要 比 多 次 执行 效率 高 。PHP 中 的 循环 有 while 循环 、do...while 循环 
和 for 循环 三 大 类 。 这 些 都 将 在 以 后 的 几 节 中 陆续 为 读者 介绍 。 本 节 先 来 学 习 while 循环 。 


5.3.1 单纯 while 判断 循环 
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在 循环 控制 中 ， 有 一 种 最 简单 的 循环 模式 : 先 判断 条 件 是 否 符合 特定 要 求 ， 如 果 符 合 就 执行 特定 
操作 ， 然 后 再 判断 ， 当 条 件 不 符合 时 则 退出 循环 。 但 如 果 一 开始 条 件 就 不 符合 要 求 ， 则 一 次 也 不 执行 ， 
直接 跳出 循环 。 这 种 循环 模式 在 PHP 中 的 表现 就 是 while 循环 。while 循环 的 使 用 模式 如 下 所 示 : 


while (expr) 


statement 
) 


说 明 : 通常 在 statement 中 有 一 条 改变 expr 值 的 语句 。 


其 中 的 expr 即 为 特定 的 条 件 ，statement 则 为 执行 的 操作 。 
【实例 5-5】 以 下 代码 演示 while 循环 的 使 用 方法 。 


02 <head> 

03 ”<title>while 循环 使 用 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 $i-1; // 初 始 化 变量 

08 while($i<10) // 判 断 变量 是 否 小 于 10 


{ 
10 echo "第 :".$i." 次 循环 "; /| 执行 操作 1 
11 echo "<br>"; /| 执行 操作 2 
12 $i++; // 变 量 自 增 
13 } 
14 ?> 
15 </body> 
16 </html> 


在 PHP 运行 环境 下 执行 以 上 代码 ， 执 行 结果 如 图 5.3 所 示 。 


[ 
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图 53 while 循环 使 用 实例 执行 结果 
程序 先 初始 化 一 个 变量 $i=1， 然 后 再 判断 变量 是 否 小 于 10， 如 果 小 于 10 就 执行 大 括号 内 的 操作 。 
当然 ， 现 在 的 变量 小 于 10， 于 是 就 打印 出 “第 : 1 次 循环 ”， 并 自 增 1， 现 在 变量 值 就 为 2。 以 此 类 推 ， 
当 循环 执行 到 第 10 次 ， 变 量 值 就 为 10， 不 再 符合 条 件 ， 于 是 就 结束 整个 过 程 。 
注意 : 必须 在 while 执 行 体 中 使 判断 条 件 的 对 象 有 所 改变 。 如 果 没 有 改变 就 会 成 为 死 循 环 。 如 实例 5-5 
中 如 果 不 让 变量 自 增 , 则 变量 的 值 永远 等 于 1, 循环 就 会 无 休止 地 执行 下 去 ,直到 耗 尽 系统 资源 。 


5.3.2 ”使 用 break 跳出 循环 
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在 使 用 while 循环 时 ， 有 时 并 不 需要 执行 到 满足 while 要 求 的 条 件 。 在 循环 执行 过 程 中 就 可 以 对 执 
行情 况 进行 判断 ， 如 果 满 足 某 一 条 件 就 使 用 break 跳出 循环 。 这 一 实现 过 程 如 下 所 示 : 


while (expr) 


statement 
if(expr1) 
t 
break; 
È 
) 


说 明 : 通常 break 会 结合 条 件 判 断 语 句 来 使 用 。 


break 的 作用 就 是 跳出 当前 循环 。 
【实例 5-6】 以 下 代码 演示 使 用 break 跳出 循环 。 


02 <head> 

03 ”<title> 使 用 break 跳出 循环 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 $i-1; /初始 化 变量 

08 while($i«10) IERI BERE ETE) 10 


KA ea 


10 echo "第 :".$i." 次 循环 "; /| 执行 操作 1 

11 echo "<br>"; /| 执行 操作 2 

12 $i++; /变量 自 增 

13 if($i==9) // 判 断 变量 情况 

14 break; // 如 果 满 足 条 件 就 跳出 循环 
15 } 

1699» 

17 </body> 

18 </html> 


通过 查看 以 上 代码 可 以 得 知 与 实例 5-5 相 比 本 实例 多 出 了 : 


if($i==9) 
break; 


执行 结果 会 有 什么 不 同 呢 ? 在 PHP 运行 环境 中 执行 以 上 代码 ， 会 得 到 如 图 5.4 所 示 的 结果 。 


LOU 
Lar 
第 ,于 
第 

LE 
8 e 
$n 
$ 


8 次 循环 


图 5.4 使 用 break 跳出 循环 实例 执行 结果 


与 实例 5-5 相 比 ， 可 以 发 现 少 执行 了 一 次 。 如 果 没 有 if($i==9) break;， 程 序 一 直 会 执行 到 $i<10， 
即 当 $i 等 于 9 时 依然 是 满足 条 件 的 。 当 使 用 了 “if($i==9) break;” 后 ， 循 环 就 在 $i 等 于 9 时 跳出 了 。 所 
以 看 不 到 第 9 次 循环 。 通 过 这 个 例子 就 可 以 发 现 break 是 如 何 起 作用 的 。 

另外 , break 除了 可 以 运用 到 while 循环 中 之 外 , 还 能 运用 到 for 循环 , 以 及 前 面 提 到 的 switch...case 
多 重 判断 中 。 作 用 都 是 跳出 当前 运行 的 过 程 。 


5.3.3 ”使 用 continue 语句 
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在 循环 结构 中 ，continue 用 
次 循环 。 


来 跳 过 本 次 循环 中 剩余 的 代码 ， 并 在 条 件 求 值 为 真 时 ， 无 条 件 执行 下 一 


【实例 5-7】 以 下 代码 演示 continue 的 工作 原理 。 


re 实例 5-7: continue 的 工作 原理 
源码 路 径 光盘 \ 源 文件 \05\5-7.php 


02 <head> 


03 ”<title> 使 用 continue 跳出 本 次 循环 实例 </title> 


04 </head> 
05 <body> 


06 <?php 

07 $i-0; 

08 while($i«10) 

09 i 

10 $i++; 

11 if($i--5) 

(2 

13 continue; 
14 ) 

15 echo "第 :“".$i." 次 循环 "; 
16 echo "<br>"; 

17 } 

18 ?» 

19 </body> 

20 </html> 
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/初始 化 变量 
// 判 断 变量 是 否 小 于 10 


// 变 量 自 增 
/判断 变量 情况 是 否 为 5 


/I 如果 满足 条 件 就 跳出 本 次 循环 


/| 执行 操作 1 
/| 执行 操作 2 


在 PHP 运行 环境 下 执行 以 上 代码 ， 执 行 结果 如 图 5.5 所 示 。 


第 
第 
第 
E 
LE 
第 , 7 
第 
$ 
第 


图 5.5 使 用 continue 跳出 本 次 循环 实例 执行 结果 
从 图 中 可 以 发 现 ， 由 于 continue 的 存在 ， 第 5 次 循环 并 没有 被 执行 。 
和 break 一 样 ，continue 同样 也 可 以 用 在 while, for. switch 语句 之 中 ， 作 用 原理 都 是 一 样 的 。 另 
外 在 使 用 continue 时 还 要 注意 ，continue 后 面 的 “;” 是 不 能 省 略 的 。 如 果 省 掉 会 导致 不 期 望 出 现 的 结果 。 


5.4 do...while 循环 
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do...while 循环 与 单纯 的 while 循环 不 同 。 单纯 的 while 循环 首先 判断 条 件 是 否 为 真 , 如 果 为 真 则 执 
行 ， 和 否则 就 不 执行 循环 。 也 就 是 说 ，while 循环 有 可 能 一 次 也 不 执行 〈 初 始 条 件 就 非 真 的 情况 ) ， 而 
do...while 循环 则 与 此 不 同 ， 它 是 先 执行 一 次 循环 ， 然 后 再 判断 条 件 是 否 为 真 ， 如 果 为 真 继续 执行 ， 否 


则 就 跳出 循环 。 它 的 执行 模式 如 下 所 示 : 


do 
t 

statement 
while (expr); 


说 明 : do...while 循 环 会 保证 循环 体 被 执行 一 次 。 
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【实例 5-8】 以 下 代码 演示 do...while 循环 的 使 用 方法 。 


re 实例 5-8: do...while 循环 的 使 用 方法 
源码 路 径 光盘 \ 源 文件 \05\5-8.php 


02 <head> 

03 ”<title>do...while 循环 使 用 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 $i-1; // 初 始 化 变量 
08 do( /开始 执行 循环 
09 echo "第 :".$i." 次 循环 "; // 执 行 操作 1 
10 echo "<br>"; /执行 操作 2 
11 $i++; NZEA 
12 )while(Si«1) // 判 断 变 量 是 否 小 于 1 
13 7» 

14 </body> 

15 «html» 


在 PHP 运行 环境 中 执行 以 上 代码 ， 执 行 结果 如 图 5.6 所 示 。 


FT 
第 ，i 次 循环 
图 5.6 do..while 循环 使 用 实例 执行 结果 


如 果 是 在 while 循环 中 ， 循 环 一 次 也 不 执行 。 因 为 变量 $i 的 值 等 于 1， 不 满足 $i<1 的 条 件 。 但 在 
do...while 循环 中 则 不 然 ， 循 环 先 执行 一 次 再 进行 判断 ， 由 于 已 经 不 满足 条 件 就 退出 循环 。 
注意 : do…while 循 环 也 要 注意 循环 条 件 ， 否 则 会 变 成 死 循 环 。 


5.5 for 循环 
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for 循环 是 PHP 中 最 复杂 的 循环 结构 。 它 的 行为 和 C 语言 的 相似 。for 循环 的 执行 模式 如 下 所 示 : 
for (expr1; expr2; expr3) 


statement 
) 


技巧 : for 循 环 中 的 各 个 表达 式 都 可 以 省 略 ， 但 是 “;” 不 可 以 省 略 。 


exprl 在 循环 开始 前 无 条 件 求 值 一 次 。 
expr2 在 每 次 循环 开始 前 求 值 。 如 果 值 为 True， 则 执行 statement 语句 。 如 果 值 为 False， 则 终 


e. 


第 5 章 PHP 中 的 流 


止 循环 。 
expr3 在 每 次 循环 后 被 执行 。 
每 个 表达 式 都 可 以 为 空 。expr2 为 空 意味 着 将 无 限 循环 下 去 ， 但 用 户 也 可 以 在 循环 体 里 加 入 break 
语句 来 终止 循环 ， 当 某 个 条 件 为 真 时 ， 就 执行 break 语句 来 跳出 for 循环 。 
【实例 5-9】 以 下 代码 演示 for 循环 的 使 用 方法 。 


re 实例 5-9: for 循环 的 使 用 方法 
源码 路 径 : 光盘 \ 源 文件 \05\5-9.php 


02 <head> 

03 ”<title>for 循环 使 用 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 for($i=1;$i<10;$i++) Iffor 循环 开始 


t 
09 echo "第 : ".$i." 次 循环 "; // 要 执行 的 语句 
10 
(Ur YA 
12 </body> 
13 </html> 


在 PHP 运行 环境 中 执行 以 上 代码 ， 执 行 结果 与 图 5.3 完全 一 样 〈 除 了 HTML. 显示 的 标题 ) 。 
通过 5.3 节 对 while 循环 的 介绍 ， 以 及 本 节 对 for 循环 的 介绍 ， 可 以 发 现 两 者 的 不 同 。 在 实际 应 用 
中 ， 若 循环 有 初始 值 ， 并 且 都 需要 递增 (或 者 递减 ) ， 这 时 使 用 for 循环 比 使 用 while 循环 要 好 。 


5.6 流程 控制 综合 运 运 用 实 例 
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本 节 将 通过 一 个 实例 ， 把 判断 与 循环 两 种 方法 结合 起 来 ， 做 一 个 实际 应 用 的 例子 。 通 过 这 个 例子 ， 
巩固 本 章 所 学 的 内 容 。 

【实例 5-10】 以 下 代码 演示 根据 二 维 数组 的 内 容 ， 以 表格 的 形式 分 类 打印 出 数组 的 全 部 内 容 ， 并 
以 不 同 的 背景 颜色 显示 大 类 别 及 小 类 别 。 


实例 5-10: 根据 二 维 数组 的 内 容 ， 以 表格 的 形式 分 类 打印 出 数组 的 全 部 内 容 ， 并 以 不 同 的 
re 背景 颜色 显示 大 类 别 及 小 类 别 
oe 源码 路 径 : 光盘 \ 源 文件 \05\5-10.php 
01 <html> 
02 <head> 
03 ”<title> 流 程控 制 综合 运用 实例 </title> 
04 </head> 
05 <body> 
06 <?php 


PHP 网 络 编程 技术 详解 


// 首 先 定义 一 个 数组 
$type[0][0]=" 学 生 用 书 "; 
$type[0][1]=" 学 生 教材 "; 
$type[0][2]=" 教 辅 用 书 "; 
$type[0][3]=" 课 外 读物 "; 
$type[0][4]=" 考 试题 集 "; 
$type[1][0]=" 名 著 "; 
$type[1][1]=" 中 国 古 典 "; 
$type[1][2]=" 世 界 名 著 "; 
$type[1][3]=" 英 文 原著 "; 
$type[2][0]=" 考 试用 书 "; 
$type[2][1]=" 公 务 员 "; 
$type[2][2]=" 会 计 师 "; 
$type[2][3]=" 医 药师 "; 
$type[3][0]=" 儿 童 读物 "; 
$type[3][1]=" 看 图 识字 "; 
$type[3][2]=" 动 漫 人 物 "; 
$type[4[0]=" 武 侠 小 说 "; 
$type[4][1]=" 金 庸 小 说 "; 
$type[4][2]=" 古 龙 小 说 "; 
$type[4][3]=" 辫 幻 小 说 "; 
echo "<table border=\"1\">"; 
for($i=0; $i<count($type); $i++) 


$s=0; 


for($j=0;$j<count($type[$i]);$j++) 


if($s%2==0) 
echo "<tr>"; 

$s++; 

if($j==0) 


echo "<td colspan=2 bgcolor=\"#cccc00\">"; 


else 


echo "<td bgcolor=\"#ccccff\">"; 


echo Stype[Si][Sj]; 
echo "</td>"; 
if($j==0) 
$s++; 
if($s%2==0) 
echo "</tr>"; 


图 书 类 型 数组 


/第 一 个 大 类 别 
// 第 一 大 类 中 的 第 一 小 类 


// 第 二 个 大 类 别 
// 第 二 大 类 中 的 第 一 小 类 


// 第 三 个 大 类 别 
/第 三 大 类 中 的 第 一 小 类 


// 第 四 个 大 类 别 
// 第 四 大 类 中 的 第 一 小 类 


// 第 五 个 大 类 别 
// 第 五 大 类 中 的 第 一 小 类 


// 打 印 表格 头 
// 外 层 循环 


// 定 义 循环 标识 变量 
/内 层 循环 


// 和 如 果 标识 为 偶数 新 起 一 行 
// 标 识 自 增 

// 判 断 是 否 为 大 类 别 

/打印 大 类 别 的 表格 


/打印 小 类 别 的 表格 

// 输 出 数据 

// 表 格 结束 

// 判 断 是 否 为 大 类 别 

/如 果 为 大 类 别 则 标识 再 次 自 增 


/如 果 大 类 别 一 格 或 小 类 别 两 格 则 表格 的 执行 结束 


if($s--(count(Stype[Si])*1) && count($typef$i])%2==0)// 判 断 小 类 别 项 为 奇数 的 情况 
echo "<td bgcolor=\"#ccccfh">&nbsp;</td></tr>";// 在 后 面 添加 空 表格 


</body> 
</html> 


说 明 : 代码 中 的 相关 HTML 代 码 读者 可 以 参考 相关 书籍 ， 本 书 不 做 介绍 。 


@ 
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在 PHP 运行 环境 中 执行 以 上 代码 ， 执 行 结果 如 图 5.7 所 示 。 


Ic 
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Pe 
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图 5.7 流程 控制 综合 应 用 实例 执行 结果 


这 个 实例 中 的 流程 控制 比较 复杂 ， 要 考虑 多 种 情况 ， 如 大 类 别 只 占 一 格 的 情况 、 小 类 别 占 两 格 的 
情况 、 小 类 别 结尾 不 足 两 格 的 情况 等 。 通 过 这 个 例子 ， 把 本 章 学 到 的 判断 、 循 环 的 知识 都 运用 到 里 面 
了 。 同 时 也 使 读者 了 解 到 ， 在 使 用 PHP 编程 时 如 何 使 用 流程 控制 来 处 理 复杂 的 问题 。 
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流程 控制 是 PHP 编程 的 基础 ， 很 多 算法 的 设计 都 要 考虑 到 流程 控制 。 本 章 学 习 了 PHP 中 的 流程 控 
制 ， 具 体内 容 包括 让 判断 、switch...case 多 重 判断 、while 循环 、do...while 循环 、for 循环 等 内 容 。 通 过 
本 章 的 学 习 ， 读 者 可 掌握 PHP 流程 控制 知识 ， 为 编写 大 型 程序 黄 定 坚实 的 基础 。 
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习题 5-1 编写 代码 : 使 用 让..else 判断 输出 两 个 变量 中 较 大 的 一 个 。 
【 分析】 该 习题 考查 读者 对 if. else 判断 运行 流程 的 掌握 。 
【关键 代码 】 
if($a>$b) 
echo $a; 
else 
echo $b; 


习题 5-2 编写 代码 : 根据 输入 的 日 期 ， 使 用 switch...case 判断 今天 是 否 休息 。 
【分 析 】 该 习题 考查 读者 对 switch...case 多 重 判断 的 掌握 。 
【关键 代码 】 


switch($day)( 
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case 1: 

case 2: 

case 3: 

case 4: 

case 5: 
echo "今天 不 休息 "; 
break; 

case 6: 

case 7: 
echo "今天 休息 "; 

} 


习题 5-3 ”编写 代码 : 使 用 while 循环 输出 1— 100 之 间 的 偶数 。 
【分 析 】 该 习题 考查 读者 对 while 循环 的 掌握 。 判 断 偶数 可 以 使 用 “$i%2==0” 比 较 表 达 式 。 
【关键 代码 】 
while($i«-100)( 
if($i%2==0) 
echo $i; 
$i++; 
} 
习题 5-4 ”编写 代码 : 使 用 for 循环 计算 1— 1000 之 间 所 有 数 的 和 。 
【分 析 】 该 习题 考查 读者 对 for 循环 的 掌握 。 
【关键 代码 】 


for($i=1;$i<=1000;$i++) 
$x+=$i; 


第 6 章 PHP 中 的 函数 


函数 是 PHP 重要 的 组 成 部 分 。 如 果 说 前 几 章 介绍 的 变量 、 表 达 式 、 流 程控 制 是 PHP 的 基础 的 话 ， 
那么 函数 就 是 PHP 的 主体 。PHP 中 有 大 量 的 库 函 数 ， 同 时 也 允许 用 户 自 定义 函数 。 本 章 就 带领 读者 来 
认识 一 下 函数 。 本 章 内 容 包括 什么 是 函数 、 函 数 的 参数 、 函 数 的 返回 值 、PHP 内 部 函数 的 使 用 、PHP 
加 载 外 部 函数 、 自 定义 函数 等 。 


61 什么 是 函数 
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简单 地 说 ， 函 数 是 为 了 完成 特定 功能 ， 而 作为 一 个 整体 存在 的 代码 块 。 例 如 ， 求 绝对 值 函数 abs() 
完成 的 功能 是 求 一 个 数 的 绝对 值 ， 而 且 它 也 是 独立 存在 的 ， 并 不 受 其 他 变量 或 函数 的 影响 。 函 数 采 用 
以 下 方法 来 定义 : 

function f_name($arg) 


{ 

expr; 

return $retval; 
} 


注意 : 函数 的 参数 即 $arg 可 以 为 室 。 


以 上 代码 中 f_name 为 函数 名 ， 用 来 区 别 其 他 函数 。$arg 为 函数 的 参数 ， 参 数 是 在 函数 执行 中 要 传 
递 的 值 ， 它 跟 在 函数 后 面 的 括号 里 。 如 果 要 求 “-3” 的 绝对 值 就 要 用 参数 来 传递 “-3”， 如 abs(-3)。 
expr 为 函数 执行 的 语句 ，S$retva 为 函数 的 返回 值 ， 返 回 值 并 不 是 每 个 函数 都 有 。 返 回 值 指 完成 函数 后 返 
回 到 主 程序 中 的 值 ， 如 abs(-3) 的 返回 值 为 3。 其 中 函数 名 的 命名 规则 与 PHP 中 的 变量 命名 规则 相同 。 
有 效 的 函数 名 以 字母 或 下 划 线 开始 ， 后 面 可 以 跟 字母 、 数 字 或 下 划 线 。 

在 PHP 3.0 中 一 个 函数 在 调用 之 前 必须 已 经 被 初始 化 。 如 果 调 用 一 个 未 被 定义 的 函数 ， 将 会 导致 
错误 。 从 PHP 4.0 开始 ， 就 不 再 有 这 种 限制 ， 这 意味 着 可 以 先 调用 一 个 并 未 被 定义 的 函数 ， 然 后 青 去 
定义 函数 。 但 是 如 果 函 数 的 定义 是 有 条 件 的 ， 那 么 在 条 件 的 定义 发 生前 ， 是 不 能 被 调用 的 。 具 体 体现 
在 如 下 两 种 情况 。 

1 有 条 件 的 定义 

具体 内 容 请 参看 以 下 代码 : 

01 <?php 


02 $makefoo=true; 
03 /* 不 能 在 这 里 调用 函数 foo()， 因 为 它 现在 并 不 存在 但 是 可 以 调用 函数 bar()*/ 
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04 bar(); // 调 用 函数 bar() 
05 if($makefoo) /定义 函数 条 件 
06 { 

07 function foo() /定义 函数 foo() 
08 T 

09 echo "foo() 函 数 。"; // 输 出 字符 串 
10 } 

11 } 

12 /* 现 在 可 以 调用 函数 foo() 了 ， 因 为 它 已 经 被 定义 */ 

13 if ($makefoo) 

14 foo(); // 调 用 函数 foo() 
15 function bar() /无 条 件 定义 函数 bar() 
16 T 

17 echo "bar() 函 数 。"; 

18 H 

19 ?> 


以 上 为 第 一 种 情况 ， 虽 然 定义 函数 的 条 件 为 真 ， 但 是 在 有 条 件 的 定义 前 ， 函 数 是 不 能 被 调用 的 。 
形象 地 说 就 是 : 如 果 某 条 件 为 真 则 再 去 考虑 是 否 去 做 某 件 事 ， 如 果 这 个 条 件 根本 不 存在 ， 就 不 考虑 去 
做 这 件 事 。 

这 里 举 一 个 形象 的 例子 。 例 如 ， 一 个 家 长 叫 小 孩子 去 买 东西 ， 小 孩子 如 何 去 买 东西 可 以 看 作 是 一 
个 函数 。 但 是 小 孩 也 给 家 长 提 了 条 件 ， 如 果 给 1 元 辛苦 发 才 去 买 。 即 具有 满足 了 给 1 元 钱 的 条 件 ， 才 
去 执行 买 东西 这 个 函数 ， 也 才 去 考虑 怎么 去 买 。 如 果 条 件 根 本 不 存在 ， 那 么 函数 相当 于 没有 定义 ， 当 
然 也 就 不 会 执行 了 。 

2 函数 的 嵌 套 定义 


第 二 种 情况 是 ， 在 某 一 函数 体 中 定义 另 一 个 函数 。 只 有 当 外 层 函 数 被 调用 时 ， 内 层 函数 才 会 被 正 
确定 义 。 所 以 也 只 有 在 调用 外 层 函 数 后 ， 才 能 调用 内 层 函 数 。 实 例如 下 : 


01 <?php 

02 function foo() 

03 

04 function bar() 

05 { 

06 echo "bar() 函 数 。"; 

07 ) 

08 ) 

09 /* 现 在 不 能 调用 函数 bar()， 因 为 它 还 未 被 定义 */ 
10 foo(); 

11 /* 现 在 可 以 调用 函数 bar()， 因 随 着 函数 foo() 的 调用 ， 函 数 bar() 也 被 正确 定义 了 */ 
12 bar(); 

13 2?» 


这 种 情况 也 很 容易 理解 ， 与 第 一 种 情况 存在 某 些 相似 之 处 。 只 是 把 定义 函数 的 条 件 转化 为 了 某 一 
函数 的 执行 。 

如 果 不 把 上 面 举例 中 的 家 长 给 钱 看 成 一 个 条 件 ， 而 是 一 个 函数 ， 就 变 成 了 第 二 种 函数 的 嵌 套 定义 
了 。 即 家 长 给 钱 的 函数 执行 了 ， 那 么 孩子 去 买 东西 这 个 函数 就 会 被 定义 ， 然 后 就 可 以 调用 函数 ， 如 怎 


[ON 


么 去 买 
另 


定义 时 
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在 6.1 节 介绍 函数 的 定义 中 ， 提 到 了 函数 的 参数 


东西 了 。 


外 在 使 用 函数 时 还 有 一 点 需要 注意 ， 与 变量 不 同 的 是 ， 函 数 名 是 大 小 写 不 敏感 的 。 如 定义 的 函 
数 为 bar0， 实 际 使 用 时 完全 可 以 通过 Bar0 来 调用 它 。 但 通常 情况 下 ， 为 了 避免 混乱 ， 调 用 时 还 是 使 用 


的 名 字 。 


62 ”函数 的 参数 


function f_name($arg) 


i 


) 


expr; 
return $retval; 


以 上 代码 中 的 $arg 就 是 一 个 参数 。 那 么 究竟 什么 是 函数 的 参数 ? 

PHP 中 的 函数 按 有 无 参数 可 分 为 有 参数 函数 和 无 参数 函数 两 种 。 函 数 参 数 只 存在 于 有 参数 的 函数 
之 中 。 函 数 参数 就 是 函数 名 称 后 圆 括号 内 的 常量 、 变 量 、 表 达 式 或 函数 。 当 定义 函数 时 ， 参 数 因为 无 
， 称 为 形式 参数 ， 形 式 参数 不 能 是 常量 值 。 当 调用 该 函数 时 ， 参 数 有 实际 的 值 ， 称 为 实际 参数 。 


实际 值 
形式 参 
[ 


Fasi 


数 的 类 型 说 明 在 函数 名 后 的 “0” 内 。 
实例 6-1】 以 下 代码 演示 函数 参数 的 使 用 。 


<html> 
<head> 
<title> 函 数 参数 的 使 用 实例 </title> 
</head> 
<body> 
<?php 
function B | text($text) 


echo "«b»«i»" $text."«/i»«/b»": 


l 
$string="PHP 编程 是 一 件 很 简单 的 事情 "; 


echo $string; 
echo "<br>"; 
B | text($string); 
?> 
</body> 
</html> 


在 调用 函数 时 也 要 注意 函数 名 的 大 小 写 。 


/定义 有 参数 函数 
/打印 字符 并 加 入 粗 体 、 斜 体 效 果 


/定义 变量 
/打印 变量 


/用 实际 参数 调用 函数 


M aaa 


在 PHP 运行 环境 中 执行 该 代码 ， 执 行 结果 如 图 6.1 所 示 。 
re 
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图 6.1 函数 参数 的 使 用 实例 执行 结果 


以 上 实例 中 ， 先 定义 了 有 形式 参数 的 函数 ， 然 后 定义 变量 并 输出 ， 再 通过 实际 参数 调用 函数 。 从 
这 个 实例 中 ， 读 者 可 以 了 解 到 函数 的 参数 是 如 何 传递 值 到 函数 体 的 。 

在 使 用 函数 参数 时 还 应 该 注意 一 个 问题 。 函 数 的 参数 是 有 类 型 限制 的 ， 即 某 一 函数 的 参数 可 能 只 
对 应 某 一 种 类 型 。 如 果 参 数 的 类 型 与 函数 要 求 的 类 型 不 一 致 ， 就 会 发 生 错误 ， 可 能 会 返回 用 户 不 希望 
的 结果 。 如 abs() 函 数 的 作用 是 计算 一 个 数 的 绝对 值 ， 所 以 它 的 参数 只 能 为 整 型 或 者 浮 点 型 数 。 如 果 用 
字符 或 者 数组 作为 函数 的 参数 ， 则 一 定 会 出 现 用 户 不 希望 的 结果 。 

另外 ， 有 的 函数 有 默认 参数 ， 这 时 的 参数 就 变 成 了 可 选 参 数 ， 即 调用 该 函数 时 可 以 不 传 和 有 默认 
值 的 参数 。 函 数 将 用 默认 值 来 蔡 换 该 参数 。 

【实例 6-2】 以 下 代码 演示 函数 默认 参数 的 使 用 。 


E i 实例 6-2: 函数 默认 参数 的 使 用 
源码 路 径 ， 光盘 \ 源 文件 \06\6-2.php 


01 «html» 

02 <head> 

03 ”<title> 函 数 有 默认 值 参 数 的 使 用 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 function B | text($text,$color-"4£000000") 

08 // 定 义 有 参数 函数 ， 其 中 $color 参数 有 默认 值 

09 ( 

10 echo "<font colorz".$color."»"; 

11 /使 用 颜色 参数 

12 echo "«b»«i»" Stext."«/i»«/b»"; 

13 // 打 印字 符 并 加 入 粗 体 、 斜 体 效果 

14 echo "</font>"; 

15 ) 

16 $string="PHP 编程 是 一 件 很 简单 的 事情 "; /定义 变量 
17 echo $string; /打印 变量 
18 echo "<br>"; 

19 B | text($string); // 调 用 函数 ， 无 $color 参数 
20 Echo "<p>"; 

21 B_i_text($string,"red"); // 调 用 函数 ， 加 入 $color 参数 
22 T> 

23 </body> 

24 «html» 


在 PHP 运行 环境 中 执行 以 上 代码 ， 执 行 结果 如 图 62 所 示 。 


e. 


不 传 入 可 选 参数 $color， 将 使 用 
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图 62 ”函数 有 默认 值 参数 的 使 用 实例 
以 上 实例 先 定义 了 一 个 有 两 个 参数 的 函数 ， 其 中 的 Scolor 参数 有 默认 值 。 即 当 调用 函数 时 ， 如 果 


默认 值 “#000000”， 即 用 黑色 打印 字体 。 所 以 第 一 次 调用 该 函数 时 没 


有 使 用 $color 函数 ， 打 印 出 的 字体 是 黑色 的 。 第 二 次 调用 时 使 用 了 “red” 作 为 $color 参数 ， 所 以 打印 


出 的 字 


体 就 是 红色 的 。 


6.3 
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在 6.1 节 讲 到 函数 时 ， 同 时 也 提 到 了 函数 的 返回 值 : 


function f_name($arg) 


{ 


) 


expr; 
return $retval; 


注意 : 函数 可 以 不 显示 返回 值 ， 如 函数 只 执行 一 系列 操作 时 。 

即 以 上 代码 中 的 $retval。 函 数 通 过 return 来 返回 值 。 函 数 的 返回 值 可 以 是 数值 、 字 符 等 变量 。 下 面 
通过 一 个 实例 来 说 明 函 数 的 返回 值 是 如 何 使 用 的 。 

【实例 6-3】 以 下 代码 演示 函数 返回 值 的 使 用 方法 。 


<head> 
<title> 函 数 返回 值 的 使 用 实例 </title> 
</head> 
<body> 
<?php 
function cube($num) 


retum $num*$num*$num; 


l 
$i-3; 


GE $i." 的 三 次 方 为 : "cube($i); 


</body> 


/定义 有 参数 函数 
/将 参数 连 乘 三 次 的 值 作为 返回 值 


/有 实际 参数 调用 函数 


© 


(000 PHPRAGEBRG 


15 </html> 
在 PHP 运行 环境 中 执行 以 上 代码 ， 执 行 结果 如 图 6.3 所 示 。 


图 63 函数 返回 值 使 用 实例 执行 结果 
男 外， 函数 不 能 有 多 个 返回 值 ， 但 是 可 以 将 数组 作为 一 个 函数 的 返回 值 来 返回 多 个 值 。 
【实例 6-4】 以 下 代码 演示 将 数组 作为 函数 的 返回 值 来 返回 多 个 值 。 


re 实例 6-4: 将 数组 作为 函数 的 返回 值 来 返回 多 个 值 
源码 路 径 ， 光盘 \ 源 文件 \06\6-4.php 


01 «html» 

02 <head> 

03 ”<title> 将 数组 作为 函数 返回 值 的 使 用 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 function E num($num1,$num2) /定义 函数 有 两 个 参数 
08 { 

09 $j-0; 

10 if($num1»$num2) // 如 果 前 面 数 大 ， 则 两 者 互 换 
11 { 

12 $temp=$num1; 

13 $num1-$num2; 

14 $num2-$temp; 

15 H 

16 for($i=$num1;$i<$num2;$i++) /循环 比较 两 数 之 间 的 值 
IT { 

18 if($i%2==0) // 选 出 其 中 的 偶数 

19 { 

20 $t[$j]=$i; // 把 结果 赋值 给 数组 元 素 
21 $j++; 

22 » 

23 H 

24 return $t; // 把 数组 $t 作为 函数 返回 值 
25 H 

26 $a-3; /定义 变量 

27 $b-20; 

28 $c-E, num($a,$b); // 调 用 函数 

29 echo $a." 到 ".$b." 之 间 的 偶数 为 : <br />"; 

30 for($i=0;$i<count($c);$i++) /遍历 数组 

31 ( 

32 echo Sc[$i]; /显示 结果 

33 echo "<br>"; 

34 ) 
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35 ?> 
36 </body> 
37 </html> 


上 面 代 码 定义 了 一 个 函数 E_num($numl,$num2), 它 的 作用 是 求 出 两 个 数 之 间 所 有 的 偶数 。 因 为 两 
数 之 间 的 偶数 可 能 有 多 个 数 ， 所 以 要 返回 多 个 数值 。 这 就 要 在 函数 中 把 这 些 数值 定义 到 数组 中 ， 然 后 
把 数组 当 作 函数 的 返回 值 返回 。 

TE PHP 运行 环境 中 执行 以 上 代码 ， 执 行 结果 如 图 6.4 所 示 。 


3 到 20 之 间 的 偶数 为 ， 


4 


图 6.4 将 数组 作为 函数 返回 值 的 使 用 实例 执行 结果 


6.4 PHP 内 部 函数 的 使 用 
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PHP 为 用 户 提供 了 丰富 的 库 函数 即 内 部 函数 ， 能 否 熟练 地 使 用 PHP 的 内 部 函数 ， 是 衡量 一 个 PHP 
程序 员 合 格 与 否 的 标准 。 那 么 如 何 使 用 PHP 中 的 库 函 数 呢 ? 由 于 内 部 函数 是 集成 在 PHP 解释 器 中 的 ， 
所 以 它 不 用 由 用 户 定义 就 可 以 直接 拿 来 使 用 。 使 用 时 只 是 要 注意 的 函数 的 参数 类 型 、 调 用 方法 、 返 回 
值 及 格式 即 可 。 
技巧 : 相关 内 部 函数 原型 可 以 从 官方 手册 获得 。 


相对 于 用 户 自 定义 函数 来 说 ，PHP 的 内 部 函数 使 用 更 简单 。 一 是 因为 它 不 用 定义 ; 二 是 不 用 担心 
函数 体会 出 错 。 

下 面 就 通过 两 个 实例 ， 来 说 明 在 PHP 中 是 如 何 使 用 库 函数 的 。 

【实例 6-5】 以 下 代码 演示 常用 的 数学 函数 的 调用 。 


c 实例 6-5. 常用 的 数学 函数 的 调用 
源码 路 径 : 光盘 \ 源 文件 ,06\6-5.php 


02 «head» 

03 «title» PHP 库 函 数 的 使 用 实例 1</title> 

04 </head> 

05 «body» 

06 <?php 

07 echo abs(-3); // 调 用 求 绝 对 值 的 库 函 数 
08 echo "<p>"; 
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09 echo floor(5.321); // 调 用 取 整 函数 

10 echo "<p>"; 

11 echo pi(); // 调 用 圆周 率 函 数 
12 echo "<p>"; 

13 echo min(5,1,3,7,8); // 调 用 求 最 小 值 函数 
14 echo "<p>"; 

15 echo max(5,1,3,7,8); // 调 用 求 最 大 值 函数 
16 ?» 

17 </body> 

18 </html> 


在 PHP 运行 环境 中 执行 以 上 代码 ， 执 行 结果 如 图 6.5 所 示 。 


3. 1415626535808 
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图 6.5 PHP 库 函数 的 使 用 实例 1 执行 结果 
【实例 6-6】 以 下 代码 演示 数组 函数 的 调用 。 


02 <head> 


O3 ”<title>PHP 库 函 数 的 使 用 实例 2</title> 
04 </head> 

05 «body» 

06 <?php 

07 $a[0]- 1; 

08 $a[1]-3; 

09 $a[2]-2; 

10 $a[3]-1; 

11 Sa[4]-2; 

12 S$a[5]-1; 

13 Sa[6]-4; 

14 $a[7]-3; 

15 print r(array count values ($a)); 
16 ?> 

17 </body> 

18 </html> 


在 PHP 运行 环境 中 执行 以 上 代码 ， 执 行 结果 如 图 6.6 所 示 。 

从 上 面 两 个 实例 中 可 以 看 出 ，PHP 的 库 函 数 有 的 不 需要 参数 ， 有 的 需要 参数 ， 有 的 还 需要 多 个 参 
数 。 所 以 在 使 用 函数 前 ， 了 解 该 函数 的 使 用 方法 是 很 有 必要 的 。 本 书 将 在 以 后 章节 中 专门 讲解 相关 的 
函数 使 用 方法 。 


e. 
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图 6.6 PHP 库 函 数 的 使 用 实例 2 执行 结果 


6.5 PHP 加载 外 部 函数 


LS LL 


PHP 有 很 多 库 函 数 ， 还 有 一 些 函数 需要 和 特定 的 PHP 扩展 模块 一 起 编译 ， 和 否则 在 使 用 它们 时 就 会 
得 到 一 个 致命 的 “未 定义 函数 ”错误 。 例 如 ， 要 使 用 图 像 函 数 如 imagecreatetruecolor()， 就 需要 在 编译 
PHP 时 加 上 对 GD 库 的 支持 。 具 体 做 法 就 是 修改 php.ini 文件 。 找 到 这 一 行 : 

;extension-php gd2.dll 

把 行 首 的 “;” 去 掉 ， 这 样 PHP 解释 器 在 启动 时 就 会 加 载 GD 库 函 数 ， 然 后 就 可 以 像 使 用 内 部 库 函 
数 一 样 使 用 GD 库 函数 。 


注意 : 有 些 库 需要 下 载 对 应 “.dll” 文 件 到 指定 文件 夹 。 


对 其 他 外 部 函数 的 使 用 也 是 如 此 ， 要 使 用 相应 的 函数 ， 就 要 先 加 载 相应 的 模块 。 有 很 多 核心 函数 
已 包含 在 每 个 版 本 的 PHP 中 , 如 字符 串 和 变量 函数 等 。 调 用 phpinfo() 函 数 ， 可 以 了 解 到 PHP 加 载 了 哪 


些 扩展 库 。 同 时 还 应 该 注意 ， 很 多 扩展 库 默认 就 是 有 效 的 。 


下 面 通过 一 个 实例 ， 来 说 明 如 何 加 载 并 使 用 外 部 函数 。 因 为 要 使 用 GD 库 函 数 ， 所 以 第 一 步 修改 
php.ini 文件 ， 去 掉 “;extension=php_gd2.dl1” 行 行 首 的 “;”。 另 外 ， 在 这 个 例子 中 要 用 到 courbd.ttf F 


体 ， 所 以 要 把 courbd.ttf 字 体 文件 复制 到 PHP 文件 的 同一 个 目录 下 。 


【实例 6-7】 以 下 代码 演示 创建 一 个 图 像 文 件 并 在 图 像 上 画 出 一 些 图 形 。 


01 


<?php 


header("Content-type:image/png"); 
Sim-imagecreatetruecolor(440, 100); 
$black-imagecolorallocate($im, 0,0,0); 


S$white- imagecolorallocate($im, 255,255,255); 


$yellow= imagecolorallocate($im,255,255,0); 
$blue = imagecolorallocate($im,0,0,255); 
$red- imagecolorallocate ($im,255,0,0); 

S$zi- imagecolorallocate($im,255,0,255); 
$font="C:\Windows\Fonts\courbd. ttf"; 
imagefilledrectangle($im, 5, 5, 435, 95, $blue); 
imagestring($im,5,7,10,"l:send",$white); 
for($i=0;$i<5;$i++) 


1/ 输出 一 个 PNG 图 片 文件 
/初始 化 图 形 区 域 
/定义 黑色 

// 定 义 白色 

/定义 黄色 
/定义 蓝 色 

/定义 红色 

/定义 紫色 

/定义 字体 文件 

/用 蓝 色 画 一 个 矩形 
IRR SN 

// 用 循环 画 字符 


@ 


(0 PHPBBRUEH GR UERE 


14 ( 

15 imagettftext($im,40,0,90-$i*50,57,$yellow,Sfont,"Z"); // 画 出 字符 用 黄色 及 字体 
16 ) 

17 imagestring($im,5,270,60,"to:YOU As a gift",$ white); /用 和 白色 写字 符 

18 imagestring($im,5,305,80,date(Y")."." date('m').".".date('d'),Swhite); // 写 出 当前 日 期 

19 imagepng($im); /创建 图 形 

20 imagedestroy($im); /关闭 图 形 

291 ?» 

在 PHP 运行 环境 中 执行 以 上 代码 ， 执 行 结果 如 图 6.7 所 示 。 


cjus 
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图 6.7 GD 库 函 数 使 用 实例 执行 结果 
因为 本 节 只 讲 怎么 使 用 外 部 函数 ， 所 以 并 不 详细 说 明 函 数 具体 是 怎么 使 用 的 。 关 于 GD 库 函 数 的 
使 用 ， 将 会 在 第 10 章 中 专门 为 读者 介绍 。 
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6.6 E EGURXE 
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在 实际 进行 PHP 编程 时 ， 由 于 要 面 对 的 情况 可 能 十 分 复杂 ， 仅 仅 依靠 PHP 内 置 的 库 函 数 ， 往 往 不 
能 实现 用 户 所 要 达到 的 目的 。 这 时 就 要 用 户 自 己 构造 函数 来 解决 实际 问题 。PHP 允许 用 户 使 用 自 定义 
函数 。 那 么 ， 自 定义 函数 应 该 怎么 用 呢 ? 本 节 就 来 解决 如 何 自 定义 函 数 、 使 用 自 定义 函数 、 函 数 的 动 
态 调 用 及 函数 的 递归 等 问题 。 


6.6.1 如 何 自 定义 函数 


YA 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 6 章 \ 如 何 自 定义 函数 .wmv 
在 PHP 中 , 自 定义 函数 是 一 件 很 简单 的 事情 。 只 需 使 用 以 下 语法 格式 就 可 以 完成 对 函数 的 自 定义 : 


function functionname() 
t 

statement; 

return $retval; 


) 
注意 : 自 定义 函数 名 不 可 以 与 函数 内 部 或 者 外 部 函数 名 相同 。 

从 以 上 代码 中 可 见 ， 要 自 定 义 函 数 ， 就 是 使 用 function 语句 ， 后 面 跟 函 数 名 加 “0”。 如 果 函 数 需 
要 参数 ， 就 要 把 参数 加 在 括号 内 。 函 数 体 部 分 用 “{}” 括 起 来 ， 以 使 之 和 其 他 语句 分 开 。 大 括号 内 是 
函数 体 ， 其 中 包括 所 要 执行 的 内 容 、 返 回 值 等 。 


@ 
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【实例 6-8】 以 下 代码 演示 如 何 完 成 自 定义 函数 。 
E a 实例 6-8. 如 何 完成 自 定义 函数 
源码 路 径 ， 光盘 \ 源 文件 \06\6-8 php 


01 <html> 

02 <head> 

03 ”<title> 函 数 的 自 定义 实例 </title> 

04 </head> 

05 «body» 

06 <?php 

07 function my. f($num1,$num2) /定义 函数 求 两 个 数 的 最 小 公 倍 数 
08 

09 if($num1»$num2) // 如 果 前 面 数 大 两 者 互 换 

10 { 

11 $temp-$num1; 

12 $num1-$num2; 

13 $num2-$temp; 

14 H 

15 $s-$num2; /定义 变量 备用 

16 $i-1; /定义 变量 备用 

(a while($s?6$num1!-0) /是 否 满 足 最 小 公 倍 数 

18 { 

19 $s=$num2*$i; IKRES 

20 $i++; 

21 H 

22 retum $s; /返回 结 果 

23 H 

24 echo my, f(1,3); /输出 1 与 3 的 最 小 公信 数 
25 echo "<p>"; 

26 echo my. f(6,8); /| 输出 6 与 8 的 最 小 公 倍 数 
27 echo "<p>"; 

28 echo my. f(13,29); /输出 13 与 29 的 最 小 公信 数 
29 echo "«p»"; 

30 echo my. f(5,100); /输出 5 5 100 的 最 小 公信 数 
31 echo "<p>"; 

32 echo my. f(35,3); /| 输出 35 与 3 的 最 小 公 倍数 
33 ?> 

34 </body> 

35 </html> 


实例 中 ， 定 义 了 一 个 函数 ， 作 用 是 通过 大 数 翻 倍 法 来 求 两 个 数 的 最 小 公 倍 数 。 在 PHP 运行 环境 中 
执行 以 上 代码 ， 执 行 结果 如 图 6.8 所 示 。 


EI 


图 6.8 ”函数 的 自 定义 使 用 实例 执行 结果 


(0 PHP 网 络 编程 技术 详解 


通过 以 上 实例 ， 读 者 能 够 理解 到 PHP 中 是 如 何 自 定义 函数 的 。 只 要 掌握 了 方法 ， 自 定义 函数 其 实 
是 一 件 很 简单 的 事情 。 


6.6.2 ”使 用 自 定义 函数 


EB 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 6 章 \ 使 用 自 定义 函数 .wmv 

自 定义 函数 在 完成 定义 后 ， 就 可 以 使 用 了 。 使 用 的 方法 也 相当 简单 ， 就 像 使 用 PHP 库 函 数 一 样 。 
如 下 所 示 : 

functionname(); 


注意 : 函数 调用 是 一 条 语句 ， 所 以 在 结尾 需要 加 “;”。 


函数 名 后 面 加 上 括号 ， 里 面 带 上 适当 的 参数 就 行 了 。 
【实例 6-9】 以 下 代码 演示 如 何 使 用 自 定义 函数 。 


02 <head> 

03 ”<title> 自 定义 函数 的 使 用 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 function my f($num1,$num2,$num3) /定义 函数 求 一 元 二 次 方程 的 根 
08 { 

09 if(($num2*$num2-4*$num1*$num3)<0) // 无 实 根 的 情况 

10 echo "方程 没有 实 根 !"; 

11 elseif(($num2*$num2-4*$num1*$num3)==0) /一 个 实 根 

12 { 

13 echo "方程 有 一 个 实 根 : <p>"; 

14 echo (-$num2+sqrt($num2*$num2-4*$num1*$num3))/(2*$num1); 
15 } 

16 else // 两 个 实 根 

17 ( 

18 echo "方程 有 两 个 实 根 : <p>"; 

19 echo (-$num2+sqrt($num2*$num2-4*$num1*$num3))/(2*$num1); 
20 echo", "; 

21 echo (-$num2-sqrt($num2*$num2-4*$num1*$num3))/(2*$num1); 
22 } 

23 } 

24 echo "H42: 2x<sup>2</sup>+3x+1=0 的 根 为 : <p>"; 

25 my. f(2,3,1); // 调 用 函数 

26 echo "<p>"; 

27 echo "方程 : x<sup>2</sup>+9x+1=0 的 根 为 : <p>"; 

28 my f(1,-6,9); // 调 用 函数 

29 echo "<p>"; 

30 echo "方程 : 3x<sup>2</sup>+2x+1=0 的 根 为 : <p>"; 


31 my f(3,2,1); 
32 ?> 

33 </body> 

34 «html» 


以 上 代码 定义 了 一 个 函数 ， 该 函数 的 作用 是 使 用 公式 法 求 一 元 二 次 方程 的 根 。 定 义 完成 后 ， 根 据 
三 种 不 同情 况 调用 函数 。 在 PHP 运行 环境 中 执行 以 上 代码 ， 执 行 结果 如 图 6.9 所 示 。 


| 
o B hapyWlocalhosty6- £ 
方程 ，2xz+3x+1=0 的 根 为 ， 
ELI 

0.5, -1 

方程 ，x*+9x+1=0 的 根 为 : 
方程 有 一 个 实 根 : 

3 

方程 ，3x*+2x+1=0 的 根 为 ， 
方程 没有 交 慌 ! 
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// 调 用 函数 


图 6.9 自 定义 函数 的 使 用 实例 执行 结果 


6.6.3 ”函数 的 动态 调用 


YA 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 6 章 \ 函 教 的 动态 调用 .wmv 
由 于 PHP 支持 可 变化 的 函数 概念 ， 所 以 如 果 在 一 个 变量 的 名 称 后 面 加 上 一 对 圆 括号 “0”， 那 么 
PHP 将 去 寻找 与 这 个 变量 名 字 相 同 的 函数 。 无 论 这 个 变量 的 数值 是 什么 ， 函 数 都 会 被 执行 。 这 个 过 程 


就 实现 


了 函数 的 动态 调用 。 


【实例 6-10】 以 下 代码 演示 函数 的 动态 调用 。 


re [m nan E 


<head> 
<title> 函 数 的 动态 调用 实例 </title> 
</head> 
<body> 
<?php 
function my_f_1($text) 


echo "<font size=12pt>"; 


echo $text; 
echo "</font>"; 


} 
function my_f_2($text) 


echo "<font size=20pt>"; 


WR: 光盘 '\ 源 文件 ,06\6-10.php 


/定义 函数 1 
/以 12 号 字体 输出 文字 


/定义 函数 2 


/以 20 号 字体 输出 文字 


ð 


M aa 


16 echo "<u>"; /给 文字 加 上 下 划 线 效果 
17 echo $text; 
18 echo "</u>"; 
19 echo "</font>"; 
20 ) 
21 $test-"my f 1"; 
22 $test("I LIKE PHP!"); /| 动态 调用 my_f_1() 函 数 
23 echo "<p>"; 
24 $test-"my f 2"; 
25 $test("Fl PHP 编程 ， 其 实 很 简单 ! "); /动态 调用 my_f_2() 函 数 
26 ?» 
27 </body> 
28 </html> 
在 PHP 运行 环境 中 执行 以 上 代码 ， 将 出 现 如 图 6.10 所 示 的 执行 结果 。 
f iol. 


[ - JOE ERE REIR 
I LIKE PHP! 
PHP 编 程 ， 其 实 很 简单 ! 


图 6.10 ”函数 的 动态 调用 实例 
以 上 代码 先 定 义 了 两 个 函数 ， 然 后 把 函数 名 称 赋 值 给 变量 。 变 量 名 后 加 上 括号 ，PHP 就 会 去 寻找 
同名 的 函数 my_f_10， 找 到 后 则 运行 ， 从 而 实现 了 函数 的 动态 调用 。 调 用 my f 20) 函 数 的 过 程 与 之 
类 似 。 


6.6.4 函数 的 递归 


GER 知识 点 讲解 :光盘 \ 视 频 讲 解 \ 第 6 章 \ 函 教 的 递归 .wmv 

本 小 节 来 介绍 PHP 函数 的 递归 。 那 么 什么 是 递归 呢 ? 其 实 递 归 就 像 读 者 都 听 过 的 一 个 歌谣 那样 : 
从 前 有 座 山 ， 山 里 有 座 庙 ， 庙 里 有 个 老 和 尚 和 一 个 小 和 尚 。 老 和 尚 给 小 和 尚 讲 故事 ， 故 事 里 说 从 前 有 
座 山 ， 山 里 有 座 庙 …… 就 像 这 样 无 限 循环 。 回 过 头 来 继续 说 递归 ， 递 归 就 是 函数 自身 调用 自身 。 

有 时 通过 函数 的 递归 来 处 理 问题 是 十 分 有 效 的 。 如 求 斐 波 纳 契 数列 第 N 项 的 值 ， 如 果 采 用 传统 方 
法 效率 很 低 。 但 如 果 使 用 函数 的 递归 ， 解 决 起 来 就 会 容易 得 多 。 下 面 就 通过 实例 来 说 明 函 数 的 递归 这 
个 问题 。 

在 列 出 具体 代码 前 ， 先 来 了 解 一 下 斐 波 纳 契 数列 的 特点 。 斐 波 纳 契 数列 即 “ 兔 子 生 兔子 的 问题 ”: 
有 一 个 人 把 一 对 兔子 放 在 四 面 围 着 的 地 方 。 假 定 每 个 月 一 对 兔子 生 下 另外 一 对 ， 而 这 新 的 一 对 在 二 个 
月 后 就 生 下 另外 一 对 。 这 样 一 年 后 会 有 多 少 对 兔子 ? 这 里 对 这 个 数列 作 一 改动 , 设 第 一 项 与 第 二 项 为 1。 
结果 就 是 这 样 的 一 组 数列 : 1，1，2，3，5，8，13，21，34，55，89，144…… 即 某 一 项 为 它 前 面 两 项 
之 和 。 在 了 解 了 数列 的 特点 后 ， 下 面 就 通过 实际 使 用 函数 的 递归 ， 来 解决 这 一 问题 。 


注意 : 在 递归 中 要 有 使 递归 中 止 的 代码 ， 不 能 使 递归 陷入 无 限 递归 之 中 。 同 时 要 避免 递归 函数 调用 超 
过 100~ 200 层 ， 因 为 可 能 会 破坏 堆栈 从 而 使 当前 脚本 终止 。 
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【实例 6-11】 以 下 代码 演示 使 用 函数 的 递归 解决 “兔子 生 免 子 ”问题 。 


re 实例 6-11: 使 用 函数 的 递归 解决 “兔子 生 兔子 ”问题 
源码 路 径 : 光盘 \ 源 文件 \06\6-11.php 


01 «html» 

02 <head> 

03 ”<title> 函 数 的 递归 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 function Fibanacci($num) /定义 Fibanacci() 函 数 
08 t 

09 if($num==1 || $num==2) // 如 果 为 第 一 项 和 第 二 项 
10 return 1; // 返 回 值 为 1 

11 else /1/ 除 1、2 外 的 其 他 项 
12 return Fibanacci($num-1)+Fibanacci($num-2); /递归 调用 前 两 项 之 和 
13 ) 

14 echo " 斐 波 纳 契 数列 的 第 1 项 为 :"; 

15 echo Fibanacci(1); 

16 echo "<p>"; 

17 echo " 斐 波 纳 契 数列 的 第 12 项 为 :"; 

18 echo Fibanacci(12); 

19 echo "<p>"; 

20 echo " 斐 波 纳 契 数列 的 第 7 项 为 : "S 

21 echo Fibanacci(7); 

22 echo "<p>"; 

23 echo " 斐 波 纳 契 数 列 的 第 20 项 为 :"; 

24 echo Fibanacci(20); 

25 7» 

26 </body> 

27 «html» 


在 PHP 运行 环境 中 执行 以 上 代码 ， 执 行 结果 如 图 6.11 所 示 。 


[€] E http://localhost/6- O ~ 


斐 波 纳 契 数列 的 第 1 项 为 ,1 


韭 波 纳 契 数列 的 第 12 项 为 ，144 
斐 波 纳 契 数列 的 第 7 项 为 ，13 
非 波 纳 契 数列 的 第 20 项 为 ，6765 


图 6.11 函数 的 递归 使 用 实例 妨 行 结果 
以 上 代码 中 当 参 数 为 1 或 2 的 情况 很 容易 理解 ， 直 接 返 回 1 即 可 。 除 此 以 外 的 情况 直接 返回 了 和 
数组 定义 完全 相同 的 公式 : 某 一 项 为 其 前 两 项 之 和 ， 从 而 实现 了 函数 的 递归 。 
可 以 看 出 ， 使 用 函数 的 递归 解决 此 类 问题 相对 于 用 普通 的 方法 法 来 说 是 简单 的 、 有 效 的 。 
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本 章 介绍 了 PHP 中 函数 的 使 用 方法 ， 其 中 讲解 了 什么 是 函数 、 函 数 的 参数 和 返回 值 、PHP 库 函 数 
的 使 用 、 外 部 函数 的 加 载 及 自 定义 函数 。 正 如 本 章 开始 时 提 到 的 ， 函 数 是 PHP 的 最 重要 的 组 成 部 分 ， 
只 有 熟练 地 使 用 函数 ， 才 算是 真正 学 会 了 PHP。 通 过 本 章 的 学 习 ， 读 者 可 对 PHP 中 函数 的 使 用 有 一 定 
了 解 。 关 于 有 具体 的 函数 如 何 用 ， 从 第 7 章 开始 将 陆续 为 读者 讲解 PHP 中 各 种 库 函 数 的 使 用 。 
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习题 6-1 定义 函数 hello0， 该 函数 的 作用 是 输出 “hello world!” . 
【分 析 】 该 习题 考查 读者 对 自 定义 函数 的 掌握 。 
【关键 代码 】 
function()( 
echo "hello world!"; 
} 


习题 6-2 定义 函数 myadd0， 该 函数 的 作用 是 返回 输入 的 两 个 参数 的 和 。 
【分 析 】 该 习题 考查 读者 对 函数 参数 和 返回 值 的 掌握 。 
【关键 代码 】 

function myadd($a,$b){ 

return $a*$b; 

E 
2]886-3 ”调用 习题 6-2 中 定义 的 myadd() 函 数 计算 75 与 93 的 和 。 
【分 析 】 该 习题 考查 读者 对 函数 调用 的 掌握 。 
【关键 代码 】 
myadd(75,93); 
习题 6-4 ”使 用 变量 $fuc 动态 调用 myadd() 函 数 。 
【分 析 】 该 习题 考查 读者 对 函数 动态 调用 的 掌握 。 
【关键 代码 】 


$fuc="myadd”; 
$fuc(); 
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本 篇 主要 介绍 了 PHP 的 数据 处 理 、 文 件 应 用 、 获 取 主 机 信息 、 图 像 处 理 、 
Session 与 Cookie、 正 则 表达 式 、 面 向 对 象 编程 以 及 MySQL 数据 库 。 通 过 本 
篇 的 学 习 ， 读 者 可 以 掌握 PHP 的 一 些 基本 应 用 编程 的 能 力 ， 可 以 编写 一 些 比 


较 实 用 的 应 用 。 


第 7 章 PHP 的 数据 处 理 
第 8 章 PHP 文件 应 用 
第 9 章 用 PHP 获取 主机 信息 


第 10 章 
第 11 章 
第 12 章 
第 13 章 
第 14 章 


PHP 中 的 图 像 处 理 
PHP 中 的 Session 与 Cooki 人 
PHP 中 正则 表达 式 的 使 用 应 
PHP 面向 对 象 编程 
使 用 MySQL 数据 库 
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数据 处 理 在 PHP 编程 中 有 重要 的 地 位 ,不 论 是 编 什么 样 的 程序 都 少不了 和 各 种 各 样 的 数据 打交道 。 
本 章 就 来 介绍 在 使 用 PHP 进行 编程 时 如 何 对 各 种 各 样 的 数据 进行 处 理 ， 包 括 怎样 判断 数据 类 型 以 及 


PHP 中 常用 的 数学 函数 、 字 符 呈 


7.1 怎样 判断 数据 类 型 


多 doi E EA ANA 章 \ 怎 样 判断 数据 类 型 .wmv 
在 使 用 数据 变量 时 ， 先 弄 清 该 变量 属于 什么 类 型 是 很 有 必要 的 。 只 有 知道 了 数据 变量 的 类 型 ， 才 
能 对 它 进 行 相关 的 操作 。 那 么 PHP 中 是 如 何 判断 数据 类 型 的 呢 ? 
1E PHP 中 有 专门 的 函数 来 判断 数据 类 型 , 这 就 是 is 系列 函数 。 常 用 的 判断 数据 类 型 的 函数 如 表 7.1 


所 示 。 


is_bool(mixed var) 
is float(mixed var) 


is int(mixed var) 


is null(mixed var) 


表 7.1 PHP 中 判断 数据 类 型 的 函数 


判断 变量 是 否 为 数组 


判断 变量 是 否 为 布尔 型 
判断 变量 是 否 为 浮 点 数 
判断 变量 是 否 为 整 型 变量 


判断 变量 是 否 为 NULL 值 


返 回 值 


如 果 参 数 var 是 数组 就 返回 True, FEE] False 

如 果 参 数 var 是 布尔 型 值 ， 即 True 或 False 就 返回 
True， 否 则 返回 False 
如 果 参 数 var 是 浮 点 数 则 返回 True， 否 则 返回 False 
如 果 参 数 var 为 整 型 变量 INT 则 返 


| False 


E] True, FWE 


如 果 参 数 var 未 被 定义 ,或 者 被 设置 为 NULL, 或 者 
虽然 已 经 被 定义 ， 但 又 被 unset0) 取 消 定 义 ， 则 返回 
True， 否 则 返回 False 


is numeric(mixed var) 


判断 变量 是 否 为 数字 或 者 数字 字符 串 


如 果 参 数 var 为 数字 或 者 数字 字符 串 则 返回 True, 否 


则 返回 False 


is object(mixed var). 


判断 变量 是 否 为 一 个 对 象 


如 果 参 数 var 为 Object 就 返回 True， 否 则 返回 False 


is_scalar(mixed var) 


判断 变量 是 否 为 一 个 标量 〈 标 量 即 最 
小 的 变量 单位 ， 只 包括 integer、float、 
string 或 boolean 的 变量 , 而 array ( 数 
组 ) object (对 象 ) 和 resource CA 
W) 则 不 是 标量 ) 


如 果 参 数 var 为 标量 则 返 


回 True， 否 则 返回 False 


isset(mixed var) 


判断 变量 是 否 为 字符 串 


判断 变量 是 否 设置 


如 果 参 数 var 为 字符 串 则 返回 True， 否 则 返回 False 


如 果 变 量 存在 就 返 


[E] True， 否 则 返 | 


jE] 


Falses 55h, WE 


设置 为 NULL 值 的 变量 在 使 用 isset() 时 也 将 返回 False， 
该 函数 只 能 用 于 变量 ， 因 为 传递 任何 其 他 参数 都 将 


造成 解析 错误 


【实例 7-1】 以 下 代码 演示 表 7.1 中 函数 的 使 


实例 7-1: 表 7.1 中 函数 的 使 用 方法 
源码 路 径 : 光盘 \ 源 文件 ,07\7-1.php 


02 «head» 
03 «title» PHP 判断 数据 类 型 函数 使 用 实例 </title> 
04 </head> 


05 <body> 
06 <?php 

07 // 先 设置 一 些 变量 备用 

08 $num1=123; 

09 Sarr-array(1,2,3,4,5,6,7); 

10 $bool1=FALSE; 

11 $b=Null; 

12 $num2-3.14159; 

13 $string1-7"123456"; 

14 $string2-" HELLO WORLD!"; 

15 class foo 

16 ( 

17 function do foo() 

18 { 

19 echo "Doing foo."; 

20 } 

21 ) 

22 $bar = new foo; 

23 if(is array(Sarr)) 

24 echo '$arr 是 数组 '; 

25 echo "«br»"; 

26 if(lis array(Snum1)) 

27 echo $num1." 不 是 数组 ! "; 
28 echo "«br»"; 

29 if(lis bool($num1)) 

30 echo $num1." 不 是 布尔 型 !"; 
31 echo "<br>"; 

32 ifis bool($boo!1)) 

33 echo $bool1." 是 布尔 型 "; 
34 echo "<br>"; 

35 if(!is_float($num1)) 

36 echo $num1." 不 是 浮 点 型 !"; 
37 echo "<br>"; 

38 if(is_float($num2)) 

39 echo $num2." 是 浮 点 型 "; 
40 echo "<br>"; 

41 if(is_int($num1)) 

42 echo $num1." 是 整 型 "; 

43 echo "<br>"; 

44 if(lis_int($num2)) 

45 echo $num2." 不 是 整 型 !"; 
46 echo "<br>"; 
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方法 。 


/定义 对 象 


// 引 用 对 象 
// 是 否 为 数组 


// 是 否 为 数组 


// 是 否 为 布尔 型 


// 是 否 为 布尔 型 


// 是 否 为 浮 点 型 


// 是 否 为 浮 点 型 


// 是 否 为 整 型 


// 是 否 为 整 型 


(0 PHPBAEGUERORUGE 


47 ifis numeric($string1)) /是 否 为 数字 或 数字 字符 串 
48 echo $string1." 是 数字 "; 

49 echo "<br>"; 

50 if(lis_numeric($string2)); /是 否 为 数字 或 数字 字符 串 
51 echo $string2." 不 是 数字 ! "; 

52 echo "<br>"; 

53 if(is object($bar)) /是 否 为 对 象 
54 echo '$bar 是 OBJCET'; 

55 echo "<br>"; 

56 if(lis object($num1)) /是 否 为 对 象 
57 echo $num1." 不 是 OBJECT! "; 

58 echo "<br>"; 

59 if(is, scalar($num1)) /是 否 为 标量 
60 echo $num1." 是 标量 "; 

61 echo "<br>"; 

62 if(lis scalar(Sarr)) // 是 否 为 标量 
63 echo '$arr 不 是 标量 ! '; 

64 echo "<br>"; 

65 if(tis string($num1)) /是 否 为 字符 串 
66 echo $num1." 不 是 字符 串 ! "; 

67 echo "«br»"; 

68 if(is, string($string1)) /是 否 为 字符 串 
69 echo $string1." 是 字符 串 "; 

70 echo "<br>"; 

71 if(isset(Sstring1)) REAA 

72 echo $string1." 有 值 "; 

73 echo "<br>"; 

74 if('isset($b)) /是 否 有 值 

75 echo $bool1." 无 值 或 者 值 为 Null! "; 

76 echo "<br>"; 

Tip, es 

78 </body> 

79 «html» 


在 PHP 运行 环境 中 执行 以 上 代码 ， 执 行 结果 如 图 7.1 所 示 。 


= | 


S htpy/localhost7- £ 


1 HF 
HELLO WORLD! 不 是 数字 ! 
$bar 是 0DJCET 


图 7.1 PHP 判断 数据 类 型 函数 使 用 实例 执行 结果 
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通过 该 实例 可 以 了 解 到 ， 在 PHP 中 使 用 相关 函数 来 判断 数据 类 型 是 一 件 很 简单 的 事情 。 
说 明 : 在 重要 的 运算 中 ， 一 定 要 注意 数据 类 型 问题 。 


7.2 PHP 中 常用 的 数学 函数 


数学 运算 和 数字 的 操作 在 PHP 的 数据 处 理 中 占有 很 大 比重 。 无 论 是 大 型 程序 ， 还 是 只 有 几 行 代码 
的 小 程序 ， 只 要 牵涉 到 数字 都 需要 用 数学 的 方法 进行 处 理 。 本 节 就 来 介绍 PHP 中 常用 的 数学 函数 。 


7.2.1 数学 计算 函数 


EB 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 7 章 \ 数 学 计算 函数 .wmv 
本 节 为 读者 介绍 常用 的 数学 计算 函数 ， 如 表 7.2 所 示 。 
表 7.2 PHP 中 常用 的 数学 计算 函数 


参数 ; 如 果 参 数 为 浮 点 型 
IUS MOL. -位 


计 TEE 计 算 e 的 指数 


会 去 法 取 整 数 函 数 ， 返 回 不 大 于 参数 | 如 果 参 数 
value 的 下 一 个 整数 > Mi 


计算 对 数 函 数 。 返 回 以 10 为 底 的 对 数 


为 整 型 数 ， 直接 返 pwa 如 果 参 数 为 浮 点 天 
值 为 参数 合 去 小 数 部 分 后 的 值 


Č | 实例 7-2. dt 72 中 所 示 函 数 的 使 用 方法 


01 «html» 

02 <head> 

03 «title» PHP 数学 计算 函数 使 用 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 echo "-3 的 绝对 值 是 : "; 

08 echo abs(-3); /| 输出 -3 的 绝对 值 
09 echo "<P>"; 

10 echo "3 的 绝对 值 是 : "S 

11 echo abs(3); /| 输出 3 的 绝对 值 
12 echo "<P>"; 

13 echo "不 小 于 5.5 的 最 小 整数 是 : "s 

14 echo ceil(5.5); /| 输出 不 小 于 5.5 的 最 小 整数 
15 echo "<P>"; 


No 
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echo "e 的 3 次 方 是 :"; 


echo "9 的 平方 根 是 : “; 


echo "不 小 于 -8.2 的 最 小 整数 是 :"; 


echo "不 大 于 3.2 的 最 大 整数 是 : "; 


echo "不 大 于 -8.8 的 最 大 整数 是 : "; 


echo "100 以 10 为 底 的 对 数 为 :"; 


说 明 : 要 了 解 这 些 函 数 的 执行 结果 可 能 需要 一 些 数学 知识 。 
在 PHP 运行 环境 中 执行 以 上 代码 ， 执 行 结果 如 图 7.2 所 示 。 


不 小 于 5. ;的 最 小 整数 是 ，6 
不 小 于 -8.2 的 最 小 整数 是 ，-8 
的 3 次 方 是 ，20. 555536923155 
不 大 于 3. ?的 最 大 整数 是 ，3 
不 大 于 -8.8 的 最 大 整 次 是 ，-9 
100 以 10 兴 底 的 对 数 为 ，2 

5 的 平方 要 是 : 3 


// 输 出 不 小 于 -8.2 的 最 小 整数 


/输出 e 的 3 次 方 


// 输 出 不 大 于 3.2 的 最 大 整数 


// 输 出 不 大 于 -8.8 的 最 大 整数 


/输出 100 以 10 为 底 的 对 数 


/| 输出 9 的 平方 根 


图 7.2 PHP 数学 计算 函数 使 用 实例 执行 结果 

通过 上 述 实例 及 执行 结果 能 够 发 现 ， 通 过 PHP 中 的 数学 计算 函数 能 对 数据 进行 各 种 数学 计算 。 熟 
练 掌握 这 些 函 数 将 对 以 后 的 数据 处 理 十 分 有 益 。 
说 明 : 对 于 这 些 函 数 要 注意 精度 问题 。 专 业 的 数学 运算 ， 最 好 使 用 数学 运算 软件 计算 。 


7.2.2 ”数学 三 角 函 数 


Gia 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 7 EA wmv 
本 节 来 介绍 常用 的 数学 三 角 函 数 。 在 介绍 三 角 函 数 之 前 先 介绍 一 个 函数 : deg2rad() 函 数 ， 


其 作用 
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是 把 角度 转换 为 弧度 。 

学 过 三 角 函 数 的 读者 都 知道 ， 三 角 函 数 就 是 指正 弦 、 余 弦 、 正 切 、 余 切 以 及 这 些 函 数 对 应 的 反 函 
数 等 。 PHP 中 也 有 类 似 的 函数 ， 并 且 表 达 方 法 几乎 与 数学 中 的 表达 方法 完全 相同 。PHP 中 常用 的 三 角 
函数 如 表 7.3 所 示 。 


表 7.3 PHP 中 常用 的 三 角 函 数 


函 数 名 作 A 返 EB 值 


sin(float arg) | 正弦 函数 返回 参数 arg 的 正弦 值 ， 参 数 arg 为 弧度 
cos(float arg) 余弦 函数 返回 参数 arg 的 余弦 值 ， 参 数 arg 为 弧度 
tan(float arg) | 正切 函数 返回 参数 arg 的 正切 值 ， 参 数 arg 为 弧度 
asin(float arg) | EUESE EC 返回 参数 arg 的 反正 弦 值 ， 参 数 arg 为 弧度 。 函 数 asin() 是 函数 sin() 的 反 函 数 
acos(float arg 反 余 弦 函 数 返回 参数 arg 的 反 余弦 值 ， 参 数 arg 为 弧度 。 函 数 acos() 是 函数 cos() 的 反 函 数 
atan(float arg) 返回 参数 arg 的 反正 切 值 ， 参 数 arg 为 弧度 。 函 数 atan0) 是 函数 tan() 的 反 函 数 


注意 : 参数 必须 是 弧度 。 如 果 是 角度 ， 必 须 先 进行 转换 。 
下 面 通过 两 个 实例 来 说 明 在 PHP 中 如 何 使 用 这 些 三 角 函 数 。 
【实例 7-3】 以 下 代码 演示 三 角 函 数 的 使 用 。 
Uu | 实例 7-3， 三 角 函 数 的 使 用 
源码 路 径 ， 光盘 \ 源 文件 \07\7-3.php 


01 <html> 

02 <head> 

03 ”<title>PHP 三 角 函 数 使 用 实例 1</title> 

04 </head> 

05 «body» 

06 <?php 

07 echo "30 度 角 的 正弦 值 为 : "; 

08 echo sin(pi()/6); /计算 正弦 
09 echo "<p>"; 

10 echo "270 度 角 的 正弦 值 为 : "; 

11 echo sin(pi()/2*3); 

12 echo "<p>"; 

13 echo "60 度 角 的 余弦 值 为 :"; 

14 echo cos(pi()/3); // 计 算 余 弦 
15 echo "«p»"; 

16 echo "0 度 角 的 余弦 值 为: " 

17 echo cos(0); 

18 echo "<p>"; 

19 echo "45 度 角 的 正切 值 为: "; 

20 echo tan(pi()/4); /计算 正切 
21 echo "<p>"; 

22 echo "90 度 角 的 正切 值 为: "; 

23 echo tan(pi()/2); 

24 echo "<p>"; 

25 echo "30 度 角 的 反正 弦 值 为 :"; 

26 echo asin(pi()/6); UWA RE 


II 


0000 PHP aeaea te 


27 
28 


35 
36 


echo "<p>"; 


echo "60 度 角 的 反 余弦 值 为 : "S 


echo acos(pi()/3); 
echo "<p>"; 


echo "45 度 角 的 反正 切 值 为 :"; 


echo atan(pi()/4); 
echo "<p>"; 


</body> 
</html> 


说 明 : 要 了 解 这些 函 数 的 执行 结果 可 能 需要 一 些 数学 知识 。 


在 PHP 运 


到 行 环境 中 执行 以 上 代码 ， 执行 结 寺 果 如 图 7.3 所 示 。 


三 [名 
[Im TEM 
270 度 角 的 正统 值 为 ，-1 
50 度 第 的 宗 弦 值 为 ，0. 5 
0 庶 角 的 余弦 值 为 ,1 
45 广 第 的 正切 值 为 ，1 


SCREEN 
1.6331 BET 16 


SOROR ÉD ESERR OS. 
0. 55106958309945 


GO EIS REUS. NAN 


图 7.3 PHP 三 角 函 数 使 用 实例 1 执行 结果 


1/ 计算 反 余弦 


// 计 算 反 正切 


【实例 7-4】 以 下 代码 演示 使 用 三 角 函 数 结合 GD 函数 来 实现 画图 功能 (更 多 关于 GD 库 函 数 的 使 
用 方法 请 参见 第 10 章 ) 。 


«?php 


Header("Content-type: image/png"); 

$im = imagecreate(400,400); 

S$black = Imagecolorallocate($im, 0,0,0); 

S$white = Imagecolorallocate($im, 255,255,255); 
Syellow = Imagecolorallocate($im,255,255,0); 
S$blue = Imagecolorallocate($im,0,0,255); 

S$red = Imagecolorallocate($im,255,0,0); 
imagefilledrectangle(S$im, 5, 5, 395, 395, $yellow); 


for($i=1;$i<360;$i++) 
t 


$tempz150*sin(2*(pi()/180)*$i); 


// 输 出 文件 头 为 PNG 图 片 


/使 用 GD 库 函 数 创建 区 域 


/使 用 GD 库 函 数 定义 黑色 
/使 用 GD 库 函 数 定义 白色 
/使 用 GD 库 函 数 定义 黄色 
// 使 用 GD 库 函 数 定义 蓝 色 
/使 用 GD 库 函 数 定义 红色 
/使 用 GD 库 函 数 画 和 矩形 


// 通 过 循环 画 点 


$x-$temp*cos((pi()/180)*$i)*200; D: 


$y-Stemp'sin((pi()/180)*$i)*-200; 


/通过 三 角 函 数 计算 值 
三 角 函 数 计算 点 的 横 坐标 
// 通 过 三 角 函 数 计算 点 的 纵 坐 标 


275 waweze VAA 


15 imagesetpixel ($im,$x,$y,$red); // 通 过 GD 库 函 数 画 点 

16 $temp=150*cos(2*(pi()/180)*$i); // 通 过 三 角 函 数 计算 第 二 个 值 
17 $x=$temp*cos((pi()/180)*$i)+200; // 通 过 三 角 函 数 计算 点 的 横 坐 标 
18 $y-S$temp'sin((pi()180)*$i)*200; /通过 三 角 函 数 计算 点 的 纵 坐 标 
19 imagesetpixel ($im,$x,$y,$blue); // 通 过 GD FAREA 

20 } 

21 ImagePNG($im); /| 输出 PNG 图 片 

22 ImageDestroy ($im); /清空 图 片 

23 ?> 


说 明 : 要 了 解 这些 函 数 的 执行 结果 可 能 需要 一 些 数学 知识 。 


在 运行 实例 7-4 中 的 代码 以 前 ， 要 加 载 GD 库 函 数 到 PHP 解释 器 中 。 保 存 代码 为 7-4.php， 然 后 在 
PHP 运行 环境 中 执行 以 上 代码 ， 执 行 结果 如 图 7.4 所 示 。 


Penre 


Jesu? P - Os 
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图 7.4 PHP 三 角 函 数 使 用 实例 2 执行 结果 
代码 运行 之 后 ， 在 屏幕 上 画 出 漂亮 的 花 的 图 案 。 这 一 方面 说 明了 PHP 功能 的 强大 ， 另 一 方面 也 体 
现 了 使 用 三 角 函 数 带 来 的 奇妙 效果 。 关 于 其 中 的 GD 库 函 数 ， 将 在 第 10 章 中 详细 介绍 。 


7.2.3 ”很 有 用 的 最 值 函数 


GHI 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 7 章 \ 很 有 用 的 最 值 函数 .wmv 
如 果 给 出 一 组 数据 要 求 求 取 其 中 的 最 大 〈 小 ) 值 ， 应 该 怎么 做 ? 在 通常 的 编程 语言 中 ， 要 先 把 一 
组 数 赋值 给 一 个 数组 ， 然 后 对 数组 进行 冒 泡 法 排序 ， 最 后 把 得 出 的 结果 赋值 给 一 个 变量 。 过 程 比较 麻 
烦 。 不 过 在 PHP 中 这 一 切 就 变 得 很 简单 , 因为 PHP. 库 函数 中 为 用 户 提供 了 求 一 组 数据 最 值 的 函数 .PHP 
中 的 最 值 函数 有 以 下 两 个 。 
加 ”max(number argl, number arg2): 求 最 大 值 函数 ， 返 回 参数 中 数值 最 大 的 值 。 如 果 仅 有 一 个 参 
数 且 为 数组 ，max0 返 回 该 数组 中 最 大 的 值 。 如 果 第 一 个 参数 是 整数 、 字 符 串 或 浮 点 数 ， 则 至 
少 需要 两 个 参数 ， 而 max0 会 返回 这 些 值 中 最 大 的 一 个 。 可 以 比较 无 限 多 个 值 。 
MI min(number argl, number arg2): 求 最 小 值 函数 ， 返 回 参数 中 数值 最 小 的 值 。 如 果 仅 有 一 个 参 
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数 且 为 数组 ，min0 返 回 该 数组 中 最 小 的 值 。 如 果 第 一 个 参数 是 整数 、 字 符 串 或 浮 点 数 ， 则 至 
少 需要 两 个 参数 ， 而 min0 会 返回 这 些 值 中 最 小 的 一 个 。 可 以 比较 无 限 多 个 值 。 


下 面 通过 两 个 实例 来 介绍 在 实际 的 编程 中 如 何 使 用 这 两 个 函数 及 注意 事项 。 
【实例 7-5】 以 下 代码 演示 max() 函 数 的 使 用 方法 。 


实例 7-5，max() 函 数 的 使 用 方法 00 - 
源码 路 径 : 光盘 \ 源 文件 ,07\7-5.php 


01 <html> 

02 <head> 

03 ”<title>max() 函 数 使 用 实例 </title> 

04 </head> 

05 «body» 

06 <?php 

07 echo "1,3,5,6,7 中 数值 最 大 的 是 : "; 

08 echo max(1,3,5,6,7); /比较 多 个 数值 
09 echo "«p»"; 

10 echo "数组 array(2,4,5) 中 最 大 的 值 是 :"; 

11 echo max(array(2, 4, 5)); /比较 一 个 数组 
12 echo "«p»"; 

13 echo "0 与 “hello” 中 最 大 的 是 : " 

14 echo max(0, 'hello"); /比较 数 及 字符 串 
15 echo "«p»"; 

16 echo" “hello” 50 中 最 大 的 是 : " 

r7 echo max('hello', 0); 

18 echo "<p>"; 

19 echo"-1 与 “hello” 中 最 大 的 是 : "; 

20 echo max(-1, 'hello'); 

21 echo "<p>"; 

22 // 对 多 个 数组 ，max 从 左 向 右 比较 

23 // 因 此 在 本 例 中 : 2 == 2, 但 4<5 

24 echo "数组 array(2,4,8) 与 数组 array(2,5,7) 中 最 大 的 是 : "5 
25 $val=max(array(2,4,8), array(2,5,7)); 

26 for($i=0;$i<count($val);$i++) 

27 

28 echo $val[Si]; 

29 echo", "; 

30 H 

31 echo "«p»"; 

32 // 如 果 同 时 给 出 数组 和 非 数组 作为 参数 ， 则 总 是 将 数组 视 为 最 大 值 返 回 
33 echo "数组 array(2,5,7)5; "string" 1042 中 最 大 的 是 : "5 
34 $val = max('string', array(2, 5, 7), 42); 

35 for($i=0;$i<count($val);$i++) 

36 

37 echo $val[Si]; 

38 echo", "; 

39 H 

40 ?» 

41 <body> 

42 </html> 
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注意 : 在 本 实例 中 应 特别 注意 对 不 同类 型 数据 的 操作 。 


在 PHP 运行 环境 中 执行 以 上 代码 ， 执 行 结果 如 图 7.5 所 示 。 
El 
[€] DIEA S noeneen 
5, 5 7 中 数值 最 大 的 是 :7 
L5 HEADE: 5 
BACKBUE. 0 
“hello” 与 0 口 最 大 所 是 :hello 
-15 "hello" ACE. hello 
flan E 


) 与 “string” 和 42 口 最 大 的 是 ，2， 


图 7.5 max() 函 数 使 用 实例 执行 结果 
从 以 上 实例 及 结果 中 可 以 看 到 max() 函 数 在 不 同情 况 下 是 如 何 运行 的 。 
【实例 7-6】 以 下 代码 演示 min() 函 数 的 使 用 方法 。 


01 <html> 

02 <head> 

03 ”<title>min() 函 数 使 用 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 echo "1,3,5,6,7 中 数值 最 小 的 是 : "S 

08 echo min(1,3,5,6,7); /比较 多 个 数值 
09 echo "<p>"; 

10 echo "数组 array(2,4,5) 中 最 小 的 值 是 : "S 

11 echo min(array(2, 4, 5)); /比较 一 个 数组 
12 echo "<p>"; 

13 echo "0 与 “hello” 中 最 小 的 是 : "S 

14 echo min(0, 'hello'); /比较 数 及 字符 串 
15 echo "«p»"; 

16 echo" “hello” 5 0 中 最 小 的 是 : "5 

uf echo min('hello', 0); 

18 echo "<p>"; 

19 echo "-1 与 “hello” 中 最 小 的 是 : "; 

20 echo min(-1, 'hello'); 

21 echo "<p>"; 


22 // 对 多 个 数组 ，min 从 左 向 右 比较 
23 // 因 此 在 本 例 中 : 2 == 2, 但 4<5 


24 echo "数组 array(2,4,8) 与 数组 array(2,5,7) 中 最 小 的 是 : "; 
25 S$val-min(array(2,4,8), array(2,5,7)); 

26 for($i=0; $i<count($val);$i++) 

27 ( 

28 echo $val[Si]; 

29 echo", "; 

30 ) 
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31 echo "«p»"; 

32 // 如 果 同 时 给 出 数组 和 非 数组 作为 参数 ， 则 不 可 能 返回 数组 。 因 为 数组 被 看 作 最 大 值 返回 
33 echo "数组 array(2,5,7)5 "string" 1142 中 最 小 的 是 : "; 

34 $val = min('string', array(2, 5, 7), 42); 

35 echo $val; 

36 ?» 

37 «body» 

38 </html> 


在 PHP 运行 环境 中 执行 以 上 代码 ， 执 行 结果 如 图 7.6 所 示 。 


[€] S imoijonton7- 2 v © | aa 
1,3,5, 6, 7 中 数值 最 小 的 是 ，1 

Eiflarres (2, 4,5) 中 最 小 的 稍 是 ， 2 
0 与 “hello” 中 最 小 的 是 ，0 

| “bello” 与 0 中 最 小 的 是 ，hel1o 
-15 “hello” 中 最 小 的 是 ，-1 

数组 arrey (2, 4, 8) 与 数组 arroy C, 5,7) 中 最 小 的 是 ，2，4，8， 
数组 array(2, 5, 7) 与 “string” 和 42 中 最 小 的 是 ，scring 


图 7.6 min() 函 数 使 用 实例 执行 结果 


通过 以 上 实例 及 执行 结果 ， 可 以 了 解 到 min() 函 数 的 运行 机 理 及 在 不 同情 况 下 的 返回 值 情况 。 

在 使 用 max0 和 min() 函 数 时 要 注意 以 下 问题 : 

两 个 函数 都 是 从 左 向 右 比 较 。 所 以 ， 如 果 相 同 的 两 个 值 比较 ， 优 先 返 回 左 边 的 值 ( 如 上 面 两 
个 实例 中 的 HELLO 字符 串 与 0 比较 的 情况 )。 

如 果 同 时 给 出 数组 和 非 数组 作为 参数 ， 则 数组 被 认为 是 最 大 的 。 所 以 ，max() 函 数 必定 返回 数 


组 ; 而 


min() 函 数 必 定 不 返回 数组 。 


注意 : 合理 使 用 最 值 函 数 ， 可 以 简化 很 多 代码 编写 量 。 


7.2.4 产生 随机 数 函 数 
GEH 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 7 章 \ 产 生 随 机 数 函 教 .wmv 


在 进行 PHP 


编程 时 ， 有 时 需要 一 些 随机 的 数字 ， 如 用 户 身份 验证 。 为 了 防止 站 外 提交 ， 应 生成 一 


组 随机 数字 ， 然 后 在 后 台 判 断 ， 如 果 随 机 数 与 系统 要 求 的 不 一 样 ， 就 不 允许 其 他 操作 。 那 么 应 该 如 何 
生成 随机 数 呢 ? PHP 中 有 专门 的 随机 数 函 数 : 


rand([int min, 


int max]) 


该 函数 用 于 产生 一 个 随机 数 。 随 机 数 的 范围 在 参数 min 与 max 之 间 。 
注意 : 如 果 rand() 函 数 省 略 参 数 ， 则 返回 0~RAND_MAX 之 间 的 伪 随 机 整数 。 


【实例 7-7】 以 下 代码 演示 rand0 函 数 的 使 用 方法 。 


实例 7-7: rand() 函 数 的 使 用 方法 
源码 路 径 ， 交 盘 \ 源 文件 077-7.php 
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01 <html> 

02 <head> 

03 ”<title>rand() 随 机 函数 使 用 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 echo "生成 一 位 随机 数 : "; 

08 echo rand(1,9); /生成 一 位 随机 数 
09 echo "<p>"; 

10 echo "生成 无 参数 随机 数 1: "S 

11 echo rand(); /无 参数 随机 数 1 

12 echo "<p>"; 

13 echo "生成 无 参数 随机 数 2:"; 

14 echo rand(); // 无 参数 随机 数 2 
15 echo "<p>"; 

16 echo "生成 四 位 随机 数 : "; 

17 echo rand(1000,9999); /| 生成 四 位 随机 数 


19 </body> 

20 </html> 

在 PHP 运行 环境 中 执行 以 上 代码 ， 执 行 结果 如 图 7.7 所 示 ( 因 生成 数 为 随机 数 ， 所 以 结果 不 一 定 
相同 ) 。 


[€] E httpy/localhost/07/7. O 
生成 一 位 随机 数 ，8 | 


生成 无 参数 随机 数 1，17465 
生成 无 参数 随机 数 2，6782 
| 生成 四 位 随机 数 ，7459 


图 7.7 randO 随 机 函数 使 用 实例 执行 结果 
通过 实例 可 见 ， 在 PHP 中 生成 一 个 随机 数 是 一 件 很 简单 的 事情 。 
在 使 用 rand() 函 数 时 有 一 点 需要 注意 ， 在 PHP 4.2 以 前 的 版 本 中 ， 要 想 使 用 rand() 函 数 必须 先 使 用 
srand0 函 数 为 rand() 生 成 种 子 ， 然 后 才能 使 用 rand0) 函 数 。 不 过 新 版 本 的 PHP. 已 经 取消 了 这 种 设 定 ， 可 
以 直接 使 用 rand(O) 函 数 。 


7.2.5” 进 制 转换 函数 


CH 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 7 章 \ 进 制 转换 函数 .wmv 

在 实际 工作 中 ， 有 时 需要 进行 进 制 的 转换 。 例 如 ， 把 十 进 制 数 转换 为 二 进 制 数 ， 或 者 把 十 六 进 制 
数 转 换 为 十 进 制 数 等 。 PHP 库 函数 中 也 为 用 户 准 备 了 这 样 的 函数 。 PHP 中 的 进 制 转换 函数 一 共有 6 个 ， 
如 表 7.4 所 示 。 
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表 7.4 PHP 中 的 进 制 转换 函数 


返 回 值 
可 参数 binary string 二 进 制 数 对 应 的 十 进 制 等 价值 
参数 mt 十 进 制 数 对 应 的 二 进 制 等 价值 
加 参数 int 十 进 制 数 对 应 的 十 六 进 制 等 价值 

回 参 数 int 十 进 制 数 对 应 的 八进制 等 价值 

加 参数 hex string 十 六 进 制 数 对 应 的 十 进 制 等 价值 
参数 octal_string 八进制 数 对 应 的 十 进 制 等 价值 


作 


用 


dechex(int number) 十 进 制 转换 为 十 六 进 制 
decoct(int number) | 十 进 制 转换 为 八进制 

hexdec(string hex string) | 十 六 进 制 转换 为 十 进 制 
八进制 转换 为 十 进 制 


octdec(string octal string) 


通过 以 上 介绍 可 以 发 现 ， 十 进 制 可 以 直接 和 二 进 制 、 八 进 制 、 十 六 进 制 进行 转换 。 同 时 ， 二 进 制 、 
八进制 、 十 六 进 制 也 可 以 直接 转换 为 十 进 制 。 
【实例 7-8】 以 下 代码 演示 如 何 使 用 进 制 转换 函数 。 


实例 7-8: 如 何 使 用 进 制 转换 函数 
源码 路 径 光盘 \ 源 文件 ,07\7-8.php 


02 <head> 

03 ”<title> 进 制 转换 函数 使 用 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 // 定 义 变量 备用 

08 $bin-"11001"; 

09 $dec-100; 

10 $hex-"12F"; 

11 S$octz"77"; 

12 echo "二 进 制 数 ".$bin." 对 应 的 十 进 制 数 为 :"; 

13 echo bindec($bin); // 二 进 制 转换 为 十 进 制 
14 echo "<p>"; 

15 echo "十 进 制 数 ".$dec." 对 应 的 二 进 制 数 为 :"; 

16 echo decbin($dec); /十进制 转换 为 二 进 制 
ur echo "<p>"; 

18 echo "十 进 制 数 ".$dec." 对 应 的 八进制 数 为 :"; 

19 echo decoct($dec); /十 进 制 转换 为 八进制 
20 echo "<p>"; 

21 echo "十 进 制 数 ".$dec." 对 应 的 十 六 进 制 数 为 : "S 

22 echo dechex(S$dec); /十 进 制 转换 为 十 六 进 制 
23 echo "<p>"; 

24 echo "八进制 数 ".$oct." 对 应 的 十 进 制 数 为 :"; 

25 echo octdec($oct); /八进制 转换 为 十 进 制 
26 echo "<p>"; 

27 echo "十 六 进 制 数 ".$hex." 对 应 的 十 进 制 数 为 :"; 

28 echo hexdec($hex); 1/ 十 六 进 制 转换 为 十 进 制 
29 echo "<p>"; 

30 echo "二 进 制 数 ".$bin." 对 应 的 八进制 数 为 :"; 

31 echo decoct(bindec($bin)); 1/ 二进制 转换 为 八进制 
32 echo "<p>"; 
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33 echo "二 进 制 数 ".$bin." 对 应 的 十 六 进 制 数 为 : "S 


34 echo dechex(bindec($bin)); /二 进 制 转换 为 十 六 进 制 
35 echo "<p>"; 
36 echo "八进制 数 ".$oct." 对 应 的 二 进 制 数 为 : "s 
37 echo decbin(octdec(Soct)); /八进制 转换 为 二 进 制 
38 echo "<p>"; 
39 echo "八进制 数 ".$oct." 对 应 的 十 六 进 制 数 为 :"; 
40 echo dechex(octdec($oct)); /八进制 转换 为 十 六 进 制 
41 echo "«p»"; 
42 echo "十 六 进 制 数 ".$hex." 对 应 的 二 进 制 数 为 :"; 
43 echo decbin(hexdec($hex)); 1/ 十 六 进 制 转换 为 二 进 制 
44 echo "<p>"; 
45 echo "十 六 进 制 数 ".$hex." 对 应 的 八进制 数 为 :"; 
46 echo decoct(hexdec($hex)); /十 六 进 制 转换 为 八进制 
47 ?> 
48 </body> 
49 </html> 
在 PHP 运行 环境 中 执行 以 上 代码 ， 执 行 结果 如 图 7.8 所 示 。 
[EI 


[€] http://localhost/07/7. © ~ C || [E] zase 

二 进 制 数 11001 对 应 的 十 进 制 数 为 ，25 

十 进 制 数 100 对 应 的 二 进 制 数 为 ，1100100 

十 进 制 数 100 对 应 的 八进制 数 为 ，144 

十 进 制 数 100 对 应 的 十 六 进 制 数 为 ，64 

八进制 数 77 对 应 的 十 进 制 数 为 ，63 

十 六 进 制 数 12F 对 应 的 十 进 制 数 为 ，303 

二 进 制 数 11001 对 应 的 八进制 数 为 ，31 

二 进 制 数 11001 对 应 的 十 六 进 制 数 为 : 19 

八进制 数 77 对 应 的 二 进 制 数 为 ，111111 

八进制 数 77 对 应 的 十 六 进 制 数 为 ，3f 

十 六 进 制 数 12F 对 应 的 二 进 制 数 为 ，100101111 
六 进 制 数 12F 对 应 的 八进制 数 为 ，457 


78 ” 进 制 转换 函数 使 用 实例 

通过 以 上 实例 及 执行 结果 可 以 发 现 ，PHP 中 实现 进 制 的 转换 还 是 比较 容易 的 。 除 了 这 6 个 函数 以 
外 ，PHP 中 还 有 一 个 函数 : 

base convert(string number,Int frombase,int tobase) 

该 函数 可 以 实现 任意 进 制 之 间 的 转换 。 它 的 返回 值 为 一 个 字符 串 , 包含 number 以 tobase 进 制 的 表 
示 。number 本 身 的 进 制 由 frombase 指定 。frombase 和 tobase 都 只 能 在 2 一 36 之 间 (包括 2 和 36) o 
高 于 十 进 制 的 数字 用 字母 a~ 表示 ， 如 a 表示 10、b 表示 11 以 及 z 表 示 35。 

【实例 7-9】 以 下 代码 演示 如 何 使 用 base_convert(O) 函 数 来 进行 进 制 转换 。 


re 实例 7-9: 如 何 使 用 base_convert() 函 数 来 进行 进 制 转换 
源码 路 径 光盘 \ 源 文件 \07\7-9.php 
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01 «html» 

02 <head> 

03 ”<title>base_convert() 函 数 使 用 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 // 定 义 变量 备用 

08 $bin="11001"; 

09 $hex="12F"; 

10 $oct="77"; 

11 echo "二 进 制 数 ".$bin." 转 为 十 六 进 制 数 为 :"; 
12 echo base convert($bin,2,16); 

13 echo "<p>"; 

14 echo "八进制 数 ".$oct." 转 为 二 进 制 数 为 :"; 
15 echo base_convert($bin,8,2); 

16 echo "<p>"; 

17 echo "十 六 进 制 数 ".$hex." 转 为 八进制 数 为 :"; 
18 echo base convert($bin, 16,8); 

19 ?> 

20 </body> 

21 «html» 


在 PHP 运行 环境 中 执行 以 上 代码 ， 其 执行 结果 如 图 7.9 所 示 。 


[€] ] S ie/ecbon7 P - O Lis 


SRRA HARB. 19 
MARR ABA: 1001000000001 
TuS EROS URSE: 210001 


图 7.9 base_convert0 函 数 使 用 实例 执行 结果 
从 执行 结果 中 可 以 发 现 ， 使 用 base_convert() 函 数 对 数据 的 进 制 进行 转换 ， 与 使 用 进 制 转换 系列 函 
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除了 前 面 介绍 的 数学 函数 之 外 ，PHP 中 还 有 几 个 常用 的 数学 函数 : hypot0、piO 函 数 等 。 下 面 分 别 
介绍 。 

hypot(float x, float y) 

该 函数 用 来 计算 直角 三 角形 斜 边 的 长 度 。 返 回 值 为 sqrt(x*x+y*y)。 

piO 函 数 无 参数 ， 返 回 圆周 率 的 近似 值 3.1415926535898。 
技巧 : 可 以 使 用 系统 预定 义 常 量 M_PI 来 代替 pi 函数 。 

这 两 个 函数 的 使 用 方法 相对 单一 ， 下 面 分 别 通过 实例 来 介绍 如 何 使 用 这 两 个 函数 。 

【实例 7-10】 以 下 代码 演示 hypotO 函 数 的 使 用 。 


[ON 
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re 实例 7-10: hypot0 函 数 的 使 用 
源码 路 径 : 光盘 \ 源 文件 ,07\7-10.php 


01 <html> 

02 <head> 

03 ”<title>hypot() 函 数 使 用 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 $a-3; /定义 变量 
08 $b-4; /定义 变量 
09 echo "直角 三 角形 的 一 直角 边 为 :".$a; 

10 echo "<br>"; 

11 echo " 另 一 直角 边 为 ".$b." 则 此 三 角形 的 斜 边 为 : "; 

12 echo hypot($a,$b); /计算 三 角形 斜 边 
13 echo "<p>"; 

14 $a-5; /定义 变量 
15 $b=12; /定义 变量 
16 echo "直角 三 角形 的 一 直角 边 为 :".$a; 

17 echo "<br>"; 

18 echo " 另 一 直角 边 为 ".$b." 则 此 三 角形 的 斜 边 为 : "; 

19 echo hypot($a,$b); 

20 7» 

21 </body> 

22 </html> 


在 PHP 运行 环境 中 执行 以 上 代码 ， 其 执行 结果 如 图 7.10 所 示 。 


直角 三 角形 的 一 直角 边 


另 一 直角 边 为 1 则 
图 7.10 hypotO 函 数 使 用 实例 执行 结果 


从 上 面 的 实例 及 执行 结果 可 见 ，hypot0 函 数 返回 sqrt(Sa*$a+Sb*$b)， 实 际 上 就 是 直角 三 角形 的 斜 边 。 
【实例 7-11】 以 下 代码 演示 pi0 函 数 的 使 用 。 
E a 实例 7-11: pi0 函 数 的 使 用 
源码 路 径 : 光盘 \ 源 文件 \07\7-11.php 


01 «html» 
02 <head> 

03 ”<title>pi() 函 数 使 用 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 echo "圆周 率 的 值 为 :"; 

08 echo pi(); /利用 pi() 函 数 输出 圆周 率 


M ea 


09 echo "<p>"; 

10 $r-10; 

11 echo "有 一 个 圆 的 半径 为 ".$r."Cm， 则 它 的 周 长 为 :"; 

12 echo number_format(2*$r*pi(),2)."Cm"; // 计 算 圆 的 周 长 并 格式 化 输出 
13 echo "<br>"; 


14 echo "此 圆 的 面积 为 :"; 

15 echo number_format(pi()*$r*$r,2)." 平 方 Cm"; // 计 算 圆 的 面积 并 格式 化 输出 
16 ?> 

17 </body> 

18 </html> 


在 PHP 运行 环境 中 执行 该 PHP 文件， 执行 结果 如 图 7.11 所 示 。 
[€] E eeitetiosi- P ~ Ò | escam 


圆周 率 的 值 为 ， 3. 1415926235898 


Em. EUREN; 62. 83Cm 
圆 的 面 裤 为 :3 


图 7.11 pi0 函 数 使 用 实例 执行 结果 


从 以 上 实例 中 可 以 了 解 到 pi0 函 数 的 运行 机 理 及 返回 值 情 况 。 至 此 ，PHP 中 的 数学 函数 就 基本 上 
介绍 完了 ，7.3 节 将 会 为 读者 介绍 PHP 中 的 字符 串 处 理 函数 。 


7.3 PHP 中 常用 的 字符 串 处 理 函 数 


字符 串 操作 的 重要 性 不 亚 于 数学 计算 。 在 PHP 编程 过 程 中 ， 不 管 是 进行 文本 处 理 还 是 字符 操作 ， 
都 离 不 开 字符 串 ， 大 量 信息 都 是 用 字符 串 来 存储 的 。 所 以 ， 只 有 善于 处 理 字符 串 才能 称 得 上 是 一 个 合 
格 的 程序 员 。 本 节 就 来 讲解 PHP 中 常用 的 字符 串 处 理 函 数 。 


7.3.1 取得 字符 串 长 度 
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要 想 处 理 一 个 字符 串 , 第 一 步 就 要 了 解 该 字符 串 的 长 度 。 在 其 他 一 些 编程 语言 (如 JavaScript) 中 ， 
字符 串 的 长 度 通常 作为 字符 串 的 一 个 属性 出 现 。 而 在 PHP 中 ， 则 需要 通过 相应 的 函数 来 取得 ， 这 个 函 
数 就 是 strlen0。 其 使 用 格式 如 下 : 

strlen(string) 


该 函数 用 来 取得 字符 串 的 长 度 。 参 数 string. 为 字符 串 变量 ， 返 回 值 为 表示 字符 串 的 整 型 变量 。 空 
字符 串 将 返回 0。 
【实例 7-12】 以 下 代码 演示 strlen0 函 数 的 使 用 。 


re 实例 7-12: strlen0) 函 数 的 使 用 
源码 路 径 : 光盘 '\ 源 文件 ,07\7-12.php 


AMI 


02 <head> 

03 ”<title> 取 得 字符 串 的 长 度 实例 </title> 

04 </head> 

05 «body» 

06 <?php 

07 $s-"asdfghjkl"; /定义 字符 串 

08 $s2="| love this game!"; /定义 字符 串 

09 echo "字符 串 ".$s." 的 长 度 为 :"; 

10 echo strlen($s); // 取 得 字符 串 的 长 度 
11 echo "<P>"; 

12 echo "字符 串 ".$s2." 的 长 度 为 :"; 

13 echo strlen($s2); // 取 得 字符 串 的 长 度 
14 ?> 

15 </body> 

16 </html> 


在 PHP 运行 环境 中 执行 以 上 代码 ， 将 会 看 到 如 图 7.12 所 示 的 执行 结果 。 
Qo »- o 
字符 号 asdfghjk] 的 长 度 为 ，9 
Ee love this game! 的 长 度 为 ，17 


图 7.12 取得 字符 串 的 长 度 实例 执行 结果 
在 使 用 strlen0 函 数 时 必须 注意 一 个 问题 ， 当 参数 为 西 文字 符 时 ， 能 正确 返回 字符 串 的 长 度 ， 而 当 
参数 为 中 文 时 ， 就 得 不 到 预想 的 结果 ， 一 个 中 文字 符 将 被 当 作 两 个 西 文字 符 来 处 理 ， 所 以 strlen) Až 
的 参数 只 能 是 西 文字 符 而 不 能 是 中 文字 符 或 者 含有 中 文字 符 。 
说 明 : 该 函数 经 常用 于 判断 用 户 名 的 长 度 是 否 符合 需要 。 


7.8.2 ”输出 字符 串 
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PHP 中 用 于 输出 字符 串 的 函数 有 以 下 儿 个 。 

echo 函数 : 用 于 字符 串 的 输出 。 从 严格 意义 上 来 讲 echo 并 不 是 一 个 真正 的 函数 ， 使 用 时 ， 不 
需要 加 “07”。 另 外 ， 它 也 没有 返回 值 。 

print() 函 数 ， 用 于 输出 字符 串 。 

print(string) 

参数 string 为 字符 串 变 量 或 者 常量 ,函数 返回 一 个 布尔 值 。 当 执行 成 功 时 返回 True, 反 之 返回 False。 

printf() 函 数 ， 用 于 将 字符 串 格式 化 输出 。 

printf(string format,mixed[args]) 

输出 格式 依照 参数 format 的 内 容 ， 具 体内 容 见 格式 化 字符 串 函 数 sprintf()。 

sprint PEZ: 用 于 格式 化 字符 串 。 

sprintf(string format,mixed[args]) 
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参数 format 是 转换 的 格式 ， 以 百分比 符号 % 开 始 到 转换 字符 为 止 。 
格式 的 内 容 顺序 如 下 。 


填空 字 元 : 0 表示 空格 ， 空 格 是 内 定 值 。 
对 齐 方式 : 内 定 值 为 向 右 对 齐 ， 负 号 CO 表示 向 左 对 齐 。 
ED RUNE: 为 最 小 宽度 。 
精确 度 : 指 在 小 数 点 后 的 浮 点 数位 数 。 
回 WAE: 如 表 7.5 所 示 。 
表 7.5 格式 化 字符 串 的 转换 字符 型 态 
格式 字符 说 mH 
Yo 印 出 百分比 符号 不 转换 
b 整数 转 成 二 进 制 
c 整数 转 成 对 应 的 ASCI 字符 
d 整数 转 成 十 进 制 
t 把 精确 度数 字 转 成 浮 点 数 
o 整数 转 成 八进制 
s 整数 转 成 字 串 
x 整数 转 成 小 写 十 六 进 制 
X 整数 转 成 大 写 十 六 进 制 


因为 echo 与 print0 函 数 相 对 简单 ， 这 里 就 不 多 做 介绍 ， 下 面 重点 介绍 一 下 sprintf0 函 数 。 
关于 如 何 使 用 sprintf() 函 数 ， 先 来 看 一 个 经 典 的 实例 : 


01 <?php 

02 $money1=68.75; 

03 $money2=54.35; 

04 $money=$money1+$money2; /此 时 变量 $money 值 为 "123.1" 

05 S$formatted-sprintf("9601.2f",Smoney); /此 时 变量 $formatted 值 为 "123.10" 
06 ?> 


上 述 代 码 中 的 %01.2f 是 什么 意思 呢 ? 

首先 % 符 号 是 开始 的 意思 ， 它 写 在 最 前 面 表示 指定 格式 要 开始 。 也 就 是 “起 始 字 符 ”， 直 到 出 现 
“转换 字符 ”为 止 ， 格 式 终止 。 

跟 在 % 符 号 后 面 的 是 0。 这 个 0 是 “填空 字 元 ”， 表 示 如 果 位 置 空 着 就 用 0 来 填 满 。 

在 0 后 面 的 是 1， 用 来 规定 小 数 点 前 面 的 数字 占 位 要 有 1 位 以 上 。 如 果 把 1 改 成 2， 则 $formatted 
的 值 将 为 01.23。 因 为 在 小 数 点 前 面 的 数字 只 占 了 1 位 ， 按 照 上 面 所 规定 的 格式 ， 小 数 点 前 数字 应 该 占 
2 位 ， 现 在 只 有 1 位 ， 所 以 用 0 来 填 满 。 

介绍 到 这 里 , 在 %01 后 面 的 .2 (点 2) 就 很 好 理解 了 , 它 的 意思 是 规定 小 数 点 后 的 数字 必需 占 2 位 。 
如 果 这 时 $money 的 值 为 1.234， 则 $formatted 的 值 将 为 1.23。 之 所 以 去 掉 了 最 后 的 4， 是 因为 按照 上 面 
的 规定 ， 在 小 数 点 后 面 数字 必须 占 2 位。 可 是 $money 的 值 中 ， 小 数 点 后 数字 占 了 3 位 ， 所 以 最 后 的 4 
只 能 被 去 掉 。 最 后 以 f 这 个 “转换 字符 ”结尾 。 其 他 转换 字符 请 参看 表 7.5。 

关于 对 齐 ， 如 果 在 % 起 始 符号 后 面 加 上 “-”《【 负 号 ) ， 则 会 把 数字 以 向 右 对 齐 的 方式 进行 处 理 。 

【实例 7-13】 以 下 代码 演示 sprintf0) 格 式 化 函数 的 使 用 方法 。 


e. 
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区 实例 7-13: sprintfl) 格 式 化 函数 的 使 用 方法 
源码 路 径 : 光盘 \ 源 文件 ,07\7-13.php 


02 <head> 

O3 ”<title>sprintf() 函 数 使 用 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 $s="123.321"; /定义 字符 串 
08 echo $s." 的 原始 值 : ".$s; 

09 echo "«p»"; 

10 S$temp-sprintf("95-1.1f",$s); /进行 格式 化 
11 echo $s." 经 过 格式 化 后 的 值 :".$temp; 

12 echo "<p>"; 

13 $s="12 3 5"; /定义 字符 串 
14 echo $s." 的 原始 值 : ".$s; 

15 echo "<p>"; 

16 S$tempzsprintf("960-b",$s); /进行 格式 化 
Xm echo $s." 经 过 格式 化 后 的 值 ".$temp; 


19 </body> 
20 </html> 


在 PHP 运行 环境 中 执行 以 上 代码 ， 执 行 结果 如 图 7.13 所 示 。 


[€] B rspylocahos7-P ~ 
23. ana, 123.391 | 
123.321 经 过 格式 化 后 的 值 ，123. 3 

5 的 原始 他 : 12 3 5 


2 2 5 经 过 格式 化 后 的 值 1100 


图 7.13 ”sprintfl) 函 数 使 用 实例 执行 结果 
在 实例 代码 中 ，$s 的 原始 值 为 123.321，%-1.1f 表示 左 对 齐 ， 小 数 点 前 后 各 有 一 位 数字 。 但 小 数 点 
前 已 经 有 3 位 ， 所 以 保留 3 位 。 小 数 点 后 面 的 3 位 则 去 掉 后 2 位 保留 1 位 。 
第 二 个 $s 的 原始 值 为 12 3 5， 先 去 掉 空 格 ， 然 后 左 对 齐 ， 再 把 得 到 的 十 进 制 整数 转化 为 二 进 制 数 。 
空格 前 只 有 一 个 12， 所 以 对 12 进行 十 进 制 到 二 进 制 的 转化 ， 结 果 为 1100， 即 8 (23) +4 (2) 。 


7.3.8 截取 字符 串 
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在 进行 字符 串 处 理 时 ， 有 时 需要 对 字符 串 进行 截取 。 在 PHP 中 要 做 到 这 一 点 也 是 很 简单 的 ， 有 一 
个 专门 的 函数 供用 户 调用 ， 这 个 函数 就 是 substr()。 其 使 用 格式 如 下 : 

Substr(string string,int start,int [length]) 

该 函数 用 于 截取 字符 串 。 参 数 string 为 字符 串 变 量 ， 参 数 start. length 为 整 型 变量 。 函 数 返 回 字符 


@ 
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HE string 从 start 开始 的 length 个 字符 。 如 果 start 为 负数 ， 则 从 字符 串 末 尾 开 始 取 。 如 果 length NE, 
则 取 从 start 到 字符 串 结 束 。 如 果 length 为 负数 ， 则 表示 取 到 倒数 第 length 个 字符 。 
【实例 7-14】 以 下 代码 演示 使 用 substr0 函 数 截取 字符 串 。 


re 实例 7-14: 使 用 substr() 函 数 截取 字符 串 
源码 路 径 : 光盘 \ 源 文件 ,07\7-14.php 


01 <html> 

02 «head» 

O3 ”<title> 截 取 字符 串 </title> 

04 </head> 

05 «body» 

06 <?php 

07 $s-"asdfghjkl"; /定义 字符 串 
08 $s2="| love this game!"; /定义 字符 串 
09 echo "字符 串 ".-$s; 

10 echo "<br>"; 

11 echo "从 3 开始 的 5 个 字符 为 :"; 

12 echo substr($s,3,5); IERCETESRS 
13 echo "<P>"; 

14 echo "字符 串 ".$s2; 

15 echo "«br»"; 

16 echo "从 2 开始 的 字符 为 :"; 

17 echo substr($s2,2); TRE TERR 
18 echo "<p>"; 

19 echo "字符 串 ".$s2; 

20 echo "<br>"; 

21 echo "从 -5 开始 的 字符 为 :"; 

22 echo substr($s2,-5); 1/ 截取 字符 串 
23 echo "<p>"; 

24 echo "字符 串 ".$s2; 

25 echo "<br>"; 

26 echo "从 2 开始 的 -6 个 字符 为 :"; 

27 echo substr($s2,2,-6); /截取 字符 串 
28 ?> 

29 </body> 

30 </html> 


在 PHP 运行 环境 中 执行 以 上 代码 ， 其 执行 结果 如 图 7.14 所 示 。 


字符 串 asdfghjkl 
JASTPBESST ERES. fghik 


字符 串 I love this game 


JA2FEBHUSETPR. love this gene! 


字符 串 I love this game! 
从 -5 开始 的 字 行 为 ，zaze! 


字符 串 I love this 
Az 开始 的 -6 个 字符 为 ， Fia this 


714 截取 字符 串 实例 执行 结果 
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上 面 代码 中 的 前 两 次 截取 都 很 好 理解 ， 不 多 解释 。 重 点 来 解释 一 下 后 面 两 次 截取 。 
substr($s2,-5): 意思 是 从 尾 端 取 5 个 到 末尾 ， 所 以 返回 game!. 
substr($s2,2,-6): 意思 是 从 第 2 个 开始 取 到 倒数 第 6 个 ， 所 以 返回 love this。 


7.3.4 按 特定 字符 切 开 字符 串 
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在 进行 字符 串 操 作 过 程 中 ,， 有 时 需要 把 一 个 较 长 的 字符 串 按照 特定 的 字符 分 割 成 若干 个 短 的 字符 。 
如 记事 本 型 数据 库 ， 通 常 把 一 行当 作 一 条 记录 ， 而 一 条 记录 中 则 通过 特定 的 标记 字符 来 分 别 存放 不 同 
的 字段 。 对 这 样 的 记录 操作 时 就 要 按 这 些 特 定 的 标记 字符 把 一 行 记 录 分 割 开 。PHP 中 提供 了 如 下 函数 
来 完成 这 项 功能 。 

explode(): 切 开 字符 串 函数 。 

explode(string separator,string string[,int limit]) 


本 函数 将 字符 串 string 依 指定 的 字符 或 字符 串 separator 分 开 ， 如 果 使 用 了 limit 参数 ， 则 返回 的 数 
组 包含 最 多 limit 个 元 素 ， 其 中 最 后 一 个 元 素 将 包含 string 的 剩余 部 分 。 函 数 的 返回 值 是 以 返回 字符 串 
为 元 素 的 字符 串 数 组 。 

split): 用 正则 表达 式 把 字符 串 分 割 到 数组 中 。 

split(string pattern,string stirng[,int limit]) 


本 函数 返回 一 个 字符 串 数组 ， 每 个 元 素 为 字符 串 string 经 过 区 分 大 小 写 的 正则 表达 式 pattern 作为 
边界 分 割 出 的 子 串 。 如 果 设 定 了 limit, 则 返回 的 数组 最 多 包含 limit 个 元 素 ,其 中 最 后 一 个 单元 包含 string 
中 剩余 的 部 分 。 如 果 出 错 ， 则 返回 False。 

strtok0: 切 开 字符 串 函 数 。 

strtok(string str,string token) 


本 函数 将 传 回 字符 串 str 依据 token 的 值 分 割 的 子 字符 串 。 
【实例 7-15】 以 下 代码 演示 分 割 字符 串 函 数 的 使 用 。 


01 «html» 

02 <head> 

03 ”<title> 切 开 字符 串 使 用 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 $s-"123|456|789"; /定义 字符 串 

08 $s2="|"; // 定 义 子 字符 串 

09 echo "字符 串 ".$s; 

10 echo "<br>"; 

11 echo "使 用 explode 方法 分 割 开 : "; 

12 $temp=explode($s2,$s); /使 用 explode() 函 数 截取 字符 串 
13 for($i=0;$i<count($temp);$i++) // 循 环 显示 返回 的 数组 元 素 
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KA PHP Rg 


14 echo $temp[Si].", "; 

15 echo "<P>"; 

16 echo "字符 串 ".$s; 

17 echo "<br>"; 

18 echo "使 用 explode 方法 加 上 参数 2 分 割 开 : "; 

19 $temp=explode($s2,$s,2); // 使 用 explode() 函 数 截取 字符 串 
20 for($i=0;$i<count($temp);$i++) // 循 环 显示 返回 的 数组 元 素 
21 echo $temp[$i]."，"; 

22 echo "<P>"; 

23 echo "字符 串 ".$s; 

24 echo "<br>"; 


25 echo "使 用 split 方法 分 割 开 : "; 


26 $temp=split('[l]',$s); /分 割 字符 定义 为 “|” 来 取 字符 串 
27 for($i=0;$i<count($temp);$i++) // 循 环 显示 返回 的 元 素 

28 echo $temp[Si].", "; 

29 echo "«P»"; 

30 echo "字符 串 ".$s; 

31 echo "<br>"; 

32 echo "使 用 strtok 方法 分 割 开 : "; 

33 $temp=strtok($s,$s2); /使 用 strtok() 函 数 截取 字符 串 
34 while($temp) // 循 环 显示 分 割 后 的 字符 串 
35 { 

36 echo $temp.", "; 

37 S$tempastrtok("|"); 

38 } 

39 ? 

40 </body> 

41 </html> 


在 PHP 运行 环境 中 执行 以 上 代码 ， 将 会 出 现 如 图 7.15 所 示 的 执行 结果 。 


189 PEE 
A MITT. 123, 456, 789, 


Ti 123|456 189 
使 用 explode 方 法 加 上 参数 2 分 割 开 ，123，4561789， 


字符 圳 123|1456|789 
使 用 =plit 方 法 分 割 开 ，123，456，789, 
宁 符 趾 12314561169 

使 用 strtok 方 法 分 割 开 ，123，456，789， 


图 7.15 切 开 字符 串 使 用 实例 执行 结果 


从 以 上 代码 的 执行 情况 可 以 看 出 ，split() 函 数 需 要 使 用 正则 表达 式 规则 ; 而 strtok0 函 数 返 回 的 只 是 


字符 串 而 不 是 字符 串 数组 ， 使 用 


explode() 函 数 切 开 字符 串 是 3 个 函数 中 最 简单 易 用 的 。 


7.3.5 去 除 字符 串 中 的 特殊 符号 
YA 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 7 章 \ 去 除 字符 事 中 的 特殊 符号 .wmv 


在 进行 实际 PHP 编程 时 ， 处 


(m, 


理 的 字符 串 有 可 能 来 自 于 网 页 ， 其 中 可 能 包含 HTML 或 者 PHP 标记 。 


这 时 就 需要 把 它们 去 除 之 后 再 做 处 理 。 在 PHP 中 也 有 专门 去 除 字符 串 中 特殊 符号 标记 的 字符 串 处 理 函 
数 strip_tags()， 格 式 如 下 : 
strip_tags(string str) 
该 函数 用 于 去 掉 字符 串 参 数 str 中 的 HTML 及 PHP 标记 , 将 处 理 之 后 的 字符 串 作为 函数 的 返回 值 。 
注意 : 此 函数 可 去 除 字符 串 中 包含 的 任何 HTML 及 PHP 标 记 。 若 是 字符 串 的 HTML 及 PHP 标 记 原 来 就 有 
错 ， 如 少 了 大 于 符号 ， 则 也 会 传 回 错误 。 


【实例 7-16】 以 下 代码 演示 如 何 使 用 strip_tags0 函 数 去 除 字符 串 中 的 特殊 标记 。 
E iN 。 实例 7-16， 如 何 使 用 strip_tags0 函 数 去 除 字符 串 中 的 特殊 标记 
源码 路 径 ， 光 盘 \ 源 文件 07\7-16.php 


02 <head> 

03 ”<title> 去 除 字符 串 的 特殊 符号 使 用 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 $s="<font color=\"#ff0000\"> 我 爱 北京 天 安 门 ! «/font»"; 
08 $t-strip tags($s); 

09 $s2="<font size=\"16pt\"> 天 安 门 上 太阳 升 ! </font>"; 
10 $t2-strip tags($s2); 

11 echo $s; 

12 echo "<p>"; 

13 echo $t; 

14 echo "<p>"; 

15 echo $s2; 

16 echo "<p>"; 

17 echo $t2; 


19 </body> 

20 </html> 

在 PHP 运行 环境 中 执行 以 上 代码 ， 其 执行 结果 如 图 7.16 所 示 。 
XI] 

Q 9e» opa 

p 


5 安 门 ! 
BERAR! 


天 安 门 上 太阳 升 ! 


天 实 门 上 太阳 升 ! 


746 去 除 字符 串 中 的 特殊 符号 使 用 实例 执行 结果 


通过 以 上 实例 发 现 ， 使 用 strip_tags() 函 数 去 除了 原 字 符 串 中 的 字体 颜色 和 字体 大 小 的 标识 ， 达 到 
了 去 除 特殊 符号 的 目的 。 


M ea 


7.3.0 ”转换 字符 串 中 的 特殊 符号 为 HTML 标记 


铬 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 7 章 \ 转 换 字 符 事 中 的 特殊 符号 为 HTML 标记 .wmv 

编写 互动 Web 网 页 时 ， 安 全 问题 是 一 定 要 考虑 的 。 一 个 不 可 忽视 的 问题 就 是 对 用 户 提交 信息 的 处 
理 。 如 果 用 户 提交 了 恶意 HTML 代码 ， 就 会 影响 到 其 他 用 户 的 使 用 ， 甚 至 会 造成 系统 瘫痪 。 所 以 编写 
互动 Web 网 页 时 ， 出 于 安全 考虑 要 对 用 户 提交 内 容 中 的 HTML 代码 进行 处 理 。 

在 PHP 中 ， 有 一 个 函数 可 以 把 用 户 提交 内 容 (字符 串 ) 中 的 特殊 符号 转换 为 HTML 实体 ， 这 个 函 
数 就 是 htmlspecialchars()， 格 式 如 下 : 

htmlspecialchars(string string) 

该 函数 实现 将 字符 串 参 数 string 中 的 特殊 符号 (如 <、>、" 等 ) 转换 为 HTML 标记 。 其 具体 转换 内 
容 如 下 : 

扩 ， 转 换 成 &amp;。 

"， 转 换 成 &quot;。 

<， 转 换 成 &lt;。 

>， 转 换 成 &gt;。 


re 实例 7-17: 如 何 使 用 htmlspecialchars() 函 数 对 字符 串 进行 转换 处 理 
源码 路 径 ， 光盘 \ 源 文件 \07\7-17.php 


01 <html> 

02 <head> 

03 ”<title> 转 换 字符 串 的 特殊 符号 为 HTML 标记 使 用 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 $s="<font color=\#ff0000\W"> 我 爱 北京 天 安 门 ! </font>"， /定义 第 一 个 字符 串 
08 $t- htmispecialchars ($s); // 对 第 一 个 字符 串 进行 处 理 
09 $s2="<font size=\"16pt\"> 天 安 门 上 太阳 升 ! </font>"; // 定 义 第 二 个 字符 串 
10 $t2-htmlspecialchars($s2); // 对 第 二 个 字符 串 进行 处 理 
11 // 分 别 输出 原 字 符 串 及 处 理 过 的 字符 串 以 查看 处 理 的 结果 

12 echo $s; 

13 echo "<p>"; 

14 echo $t; 

15 echo "<p>"; 

16 echo $s2; 

17 echo "«p»"; 

18 echo $t2; 

19 ?> 

20 </body> 

21 «html» 


在 PHP 运行 环境 中 执行 以 上 代码 ， 其 执行 结果 如 图 7.17 所 示 。 
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s78 moga 000 


CEES 


DJE kombo P ~ Q| BP 


XS] EAE 


«font size="16pt> 天 去 门 上 太阳 升 ! "font 


7.17 ”转换 字符 串 的 特殊 符号 为 HTML 标记 使 用 实例 执行 结果 
通过 以 上 实例 可 见 ，htmlspecialchars() 函 数 把 字符 串 中 的 特殊 符号 都 转换 成 了 HTML. 标记 。 经 过 这 
样 的 处 理 ， 加 入 字符 串 中 的 HTML 代码 都 将 因 被 转化 而 不 能 起 作用 ， 这 样 在 客观 上 就 起 到 了 提高 安全 
性 的 效果 。 
技巧 : 在 一 些 网 站 需要 展现 HTML 代 码 ， 而 避免 被 浏览 器 解析 ， 可 以 采用 这 种 方法 。 


7.3.7 ”加 入 转 义 符 


(UE 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 7 PANES wmv 
在 数据 库 操作 时 ， 如 果 把 未 经 操作 的 单 引 号 写 入 库 里 就 会 使 SQL 语句 发 生 错误 。 所 以 给 特殊 字符 
加 上 转 义 符 就 显得 尤为 重要 。 同 理 ， 显 示 时 就 要 把 转 义 符 去 除 ， 这 样 库 里 的 内 容 才能 正常 显示 。 因 此 
加 入 转 义 符 函数 addslashes(string str) 和 去 除 转 义 符 函 数 stripslashes(string str) 在 PHP 里 也 经 常用 到 。 
这 两 个 函数 的 使 用 与 用 户 的 PHP 解释 器 的 设置 有 关 。php.ini 是 PHP 设置 的 核心 文件 。 其 中 的 
magic quotes gpc 项 的 开关 对 这 两 个 函数 有 着 直接 的 影响 。 通 常 有 以 下 两 种 情况 。 
magic_quotes_gpc=on: 可 以 不 对 输入 和 输出 数据 库 的 字符 串 数据 做 addslashes0 和 stripslashes() 
的 操作 ， 数 据 也 会 正常 显示 。 如 果 此 时 对 输入 的 数据 做 了 addslashes() 处 理 ， 那 么 在 输出 时 就 
必须 使 用 stripslashes() 去 掉 多 余 的 转 义 符 。 
magic quotes gpc-off: 必须 使 用 addslashes() 对 输入 数据 进行 处 理 ， 但 并 不 需要 使 用 
stripslashes() 格 式 化 输出 ， 因 为 addslashes0 并 未 将 转 义 符 一 起 写 入 数据 库 ， 只 是 帮助 MySQL 
完成 了 SQL 语句 的 执行 。 
说 明 : 由 于 这 两 个 函数 罕 涉 数据 库 的 操作 ， 本 节 只 给 出 简单 提示 ， 具 体操 作 请 参见 第 14 章 。 


7.3.8 ”比较 字符 串 函 数 


(E 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 7 章 \ 比 较 字 符 囊 函数 .wmv 

两 个 数值 ， 不 论 是 整 型 还 是 浮 点 型 都 能 够 比较 大 小 ， 而 两 个 字符 串 也 可 以 比较 大 小 。 在 PHP 中 ， 
有 一 个 函数 专门 用 来 比较 字符 串 的 大 小 ， 这 个 函数 就 是 stremp()。 其 使 用 格式 如 下 : 

int strcmp(string str1,string str2) 

参数 strl 与 str2 表示 两 个 字符 串 变量 ， 函 数 返 回 一 个 整数 。 如 果 strl 大 于 str2 则 返回 正 数 ， 如果 
strl 小 于 str2 则 返回 负数 ， 如 果 两 个 字符 串 完 全 一 致 则 返回 0。 
说 明 : 字符 串 比较 大 小 的 规则 是 ， 从 左 向 右 比较 ， 比 较 同一 位 置 字 符 的 ASCII 值 。 


KI 


KA aaa 


【实例 7-18】 以 下 代码 演示 如 何 使 用 strcmp() 函 数 。 


TE | 实例 7-18: 如 何 使 用 stremp() 函 数 


源码 路 径 : 光盘 \ 源 文件 ,07\7-18.php 


01 <html> 

02 <head> 

03 ”<title> 比 较 字符 串 的 大 小 函数 使 用 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 $s-"abcdefg"; /定义 变量 

08 $s2-"abddefg"; 

09 $s3-"abddefg"; 

10 echo $s; 

11 echo "<p>"; 

12 echo $s2; 

13 echo "«p»"; 

14 echo $53; 

15 echo "<p>"; 

16 function bijiao(Sstr1,$str2) /| 基于 strcmp() 函 数 ， 构 造 一 个 函数 
17 i 

18 if(stremp($str1,$str2)>0) // 如 果 第 一 个 字符 串 大 于 第 二 个 ， 则 返回 正 数 
19 echo $str1." 大 于 ".$str2; 

20 elseif(stremp($str1,$str2)«0) // 如 果 第 一 个 字符 串 小 于 第 二 个 ， 则 返回 负数 
21 echo $str1." 小 于 ".$str2; 

22 else /如 果 两 个 字符 串 相等 ， 则 返回 0 
23 echo $str1." 等 于 ".$str2; 

24 ) /bijiao() 函 数 结束 

25 bijiao($s,$s2); // 调 用 自 定义 函数 bijiao() 

26 echo "<p>"; 

27 bijiao($s2,$s); 

28 echo "«p»"; 

29 bijiao($53,$52); 

30 echo "<p>"; 

931 75» 

32 </body> 

33 </html> 


在 PHP 运行 环境 中 执行 以 上 代码 ， 其 执行 结果 如 图 7.18 所 示 。 


S nap://localhost7- £ 


| abddefg 


abddefg 

abcdefg;| Fabddeig 
ahdlie 人 大 于 ahcd= 记 
abdice S Fabddele 


图 7.18 ”比较 字符 串 的 大 小 函数 使 用 实例 执行 结果 
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从 以 上 执行 结果 可 见 ， 返 回 结果 符合 比较 规则 。 通 过 该 实例 ,读者 既 能 明白 strcmp() 函 数 的 使 用 方 
法 ， 同 时 也 巩固 了 自 定义 函数 的 使 用 。 


7.8.9 改变 字符 串 的 大 小 写 


CÈ 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 7 章 \ 改 变 字符 串 的 大 小 写 .wmv 

在 进行 字符 串 处 理 时 ， 有 时 需要 对 字符 串 中 字母 的 大 小 写 进行 转换 ， 这 时 就 需要 用 到 strtolower() 
和 strtoupperO) 函 数 。 其 使 用 格式 如 下 : 

string strtolower(string str) 

该 函数 用 于 把 字符 串 参 数 str 中 的 所 有 大 写字 母 转换 为 小 写字 母 ， 把 转换 后 的 新 字符 串 作 为 函数 的 
返回 值 。 

string strtoupper(string str) 

该 函数 用 于 把 字符 串 参 数 str 中 的 所 有 小 写字 母 转换 为 大 写字 母 ， 把 转换 后 的 新 字符 串 作 为 函数 的 
返回 值 。 

【实例 7-19】 以 下 代码 演示 改变 字符 串 大 小 写 函数 的 使 用 。 


re 实例 7-19: 改变 字符 串 大 小 写 函数 的 使 用 
Ar.) 源码 路 径 ， 光盘 \ 源 文件 \077-19.php_ 


01 <html> 

02 <head> 

03 ”<title> 改 变 字符 串 大 小 写 函 数 的 使 用 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 $s="| Love My Great Country!"; /定义 变量 
08 S$temp1=strtolower($s); /| 转换 为 小 写字 母 
09 $temp2-strtoupper($s); /| 转换 为 大 写字 母 
10 echo " 原 字符 为 :"; 

11 echo $s; 

12 echo "«p»"; 

13 echo " 原 字 符 经 过 strtolower() 处 理 后 的 值 为 : "; 

14 echo "<br>"; 

15 echo $temp1; /打印 结果 
16 echo "«p»"; 

17 echo " 原 字 符 经 过 strtoupper() 处 理 后 的 值 为 : ”; 

18 echo "<br>"; 

19 echo $temp2; /打印 结果 
之 OU 

21 </body> 

22 </html> 


在 PHP 运行 环境 中 执行 以 上 代码 ， 其 执行 结果 如 图 7.19 所 示 。 
查看 以 上 执行 结果 发 现 ， 经 过 strtolower0) 函 数 处 理 的 字符 串 内 容 全 变 为 小 写 ; 而 经 过 strtoupper() 
函数 处 理 的 字符 串 内 容 全 变 成 了 大 写 。 


0000 r aeaea te 
[€] > errentaz- o -Ó 


原 字 符 为 ，1Lore My Great Country! 


原 字 符 经 过 strtolower0 处 理 后 的 值 为: 
uy! 


i love my great coum 


原 宁 香 经 辽 strtoupper0 处 理 后 的 值 为: 
ILOVEMY GREAT COUNTRY! 


图 7.19 改变 字符 串 大 小 写 函 数 的 使 用 实例 执行 结果 
说 明 : 该 功能 适用 于 对 用 户 的 名 称 的 预 处 理 ， 便 于 比 对 。 


7.3.10 ”其 他 常用 字符 串 处 理 函 数 


JA 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 7 章 \ 其 他 常用 字符 串 处 理 函 数 .-wmv 

除了 前 面 介绍 的 字符 串 处 理 函数 之 外 ， 在 进行 PHP 编程 及 字符 串 处 理 过 程 中 ， 还 有 其 他 一 些 常用 
的 字符 串 处 理 函 数 。 由 于 相对 于 前 几 小 节 介绍 的 函数 ， 这 些 函 数 使 用 频率 较 低 ， 所 以 只 对 它们 的 使 用 
格式 、 参 数 、 返 回 值 等 情况 做 简单 介绍 。 

string chop() 函 数 : 

string chop(string str) 

该 函数 用 于 去 除 字符 串 ste 中 的 连续 空白 ， 返 回 值 为 处 理 后 的 字符 串 。 

string ltrim() 函 数 : 

string Itrim(string str) 

该 函数 功能 与 chop0 函 数 类 似 ， 也 是 去 除 字符 串 中 的 连续 空白 带 (whitespace》， 并 把 处 理 结果 返回 。 

string md5() 函 数 : 

string md5(string str) 

该 函数 用 于 把 字符 串 str 进行 MD5 加 密 ， 并 把 加 密 后 的 字符 串 作为 函数 的 返回 值 。 该 函数 在 处 理 
用 户 的 密码 时 经 常用 到 ， 一 般 是 把 用 户 密码 经 md50 函 数 加 密 后 再 入 库 。 

string nl2br0) 函 数 : 

string nl2br(string str) 

该 函数 用 于 把 字符 串 str 中 的 回 车 换行 转换 为 HTML 标记 中 的 <br>， 并 把 处 理 结果 返回 。 这 也 是 
一 个 很 有 用 的 函数 ， 特 别 是 在 用 户 提交 的 内 容 中 存在 换行 时 ， 使 用 该 函数 就 能 保持 用 户 输入 的 格式 。 

string str replace() FK Zi: 

string str replace(string needle, string str, string haystack) 

该 函数 将 字符 串 str 代入 haystack 字符 串 中 ， 将 所 有 的 needle 置换 成 str。 例 如 ， 使 用 str replace 
("a","b","abcd")， 函 数 将 返回 bbcd。 

FE, PHP 中 常用 的 字符 串 处 理 函 数 就 讲解 完了 ， 在 编程 过 程 中 只 有 经 常 使 用 才能 熟练 掌握 这 些 
函数 。 


@ 
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在 PHP 编程 过 程 中 ， 有 相当 大 的 部 分 是 与 数组 打交道 ， 如 入 库 的 内 容 、 统 计 相关 内 容 等 操作 都 离 
不 开 数组 ， 很 多 信息 都 是 用 数组 作为 载体 的 。 所 以 数组 的 操作 在 PHP 编程 中 占有 很 大 的 比重 ， 只 有 部 
练 地 操作 数组 才能 熟练 编写 PHP 程序 。 本 节 就 来 介绍 PHP 中 常用 的 数组 处 理 函数 。 


7.4.1 新建 一 个 数组 


GEH 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 7 章 \ 新 建 一 个 数组 .wmv 

既然 要 操作 数组 ， 第 一 步 就 是 要 新 建 一 个 数组 。 新 建 数组 也 有 相关 的 函数 ， 这 个 函数 就 是 array0。 
回忆 前 面 对 数 组 的 一 些 介绍 可 知 ， 新 建 一 个 数组 通常 有 两 种 方法 : 一 种 是 直接 给 数组 每 个 变量 赋值 ; 
另 一 种 是 同时 给 数组 所 有 元 素 赋值 。 给 数组 所 有 元 素 同 时 赋值 时 就 要 用 到 array0 函 数 。 

array() 函 数 用 来 新 建 一 个 数组 ， 传 回 的 数值 是 数列 形态 。 参 数 可 以 是 带 有 => 运 算 符 的 索引 。 
注意 : 从 实质 上 来 说 ，array() 并 不 算是 一 个 正规 的 函数 ， 它 主要 是 用 来 建立 数组 。 


【实例 7-20】 以 下 代码 演示 array() 函 数 的 使 用 ， 同 时 也 可 复习 一 下 如 何 新 建 一 个 数组 。 


re 实例 7-20:，array0 函 数 的 使 用 
源码 路 径 ， 光盘 \ 源 文件 \07\7-20.php 


01 <html> 

02 <head> 

03 ”<tile>array() 函 数 使 用 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 $temp-array(1,2,3,4,5,6); /定义 数组 $temp 
08 $temp1=array(0=>"zero", 

09 1=>"one", 

10 2=>"two", 

11 3=>"three" 

12 y /定义 数组 Stemp1 
13 $temp2=array("name"=>" 张 三 ", 

14 "sex"=>" 男 "， 

15 "age"=>"20" 

16 y /定义 数组 $temp2 
17 echo $temp[0]; /| 输出 数组 

18 echo", "; 

19 echo Stemp[1]; 

20 echo", "; 

21 echo $temp[2]; 

22 echo", "; 

23 echo $temp[3]; 

24 echo", "; 


KA ea 


25 echo $temp[4]; 

26 echo", "; 

27 echo $temp[5]; 

28 echo", "; 

29 echo "<p>"; 

30 for($i=0;$i<count($temp1);$i++) // 循 环 输出 数组 
31 echo $temp1[Si].", "; 

32 echo "<p>"; 

33 echo $temp2['name"]; // 输 出 数组 
34 echo "«p»"; 

35 echo $temp2["sex"]; 

36 echo "<p>"; 

37 echo $temp2["age"]; 

38 ?> 

39 </body> 

40 </html> 


在 PHP 运行 环境 中 执行 以 上 代码 ， 执 行 结果 如 图 7.20 所 示 。 


zero. one. two. three, 


图 7.20 array() 函 数 使 用 实例 执行 结果 
以 上 实例 不 仅 使 读者 了 解 了 array0) 函 数 的 使 用 方法 ， 更 加 深 了 读者 对 如 何 建 立 一 个 数组 的 理解 。 


74.2 计算 数组 的 元 素 个 数 


F 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 7 章 \ 计 算数 组 的 元 素 个 数 .wmv 

在 对 一 个 数组 操作 之 前 ， 得 知 数组 的 元 素 个 数 是 很 有 必要 的 。 如 要 对 数组 循环 输出 ， 只 有 当知 道 
了 数组 的 元 素 个 数 时 才能 进行 。 在 PHP 中 计算 数组 元 素 个 数 的 方法 非常 简单 ， 可 以 使 用 count() 函 数 来 
完成 。 格 式 如 下 : 


count(mixed var) 


该 函数 的 参数 可 以 是 数组 或 整数 变量 。 如 果 参 数 是 数组 ， 则 返回 数组 元 素 的 个 数 ， 如果 参 数 为 整 
数 ， 则 分 两 种 情况 : 如 果 整 数 变量 还 没有 值 则 返回 0， 如 果 已 经 赋值 则 返回 1。 
【实例 7-21】 以 下 代码 演示 countO 函 数 的 使 用 方法 。 


re 实例 7-21: count0 函 数 的 使 用 方法 
源码 路 径 : 光盘 \ 源 文件 \07\7-21.php 


01 <html> 
02 <head> 
03 ”<title> 计 算数 组 的 元 素 个 数 实例 </title> 


(CN 


04 </head> 

05 <body> 

06 <?php 

07 S$arr1[0]-"zero"; 

08 Sarr1[1]-"one"; 

09 Sarr1[2]-"two"; 

10 S$arr1[3]-"three"; 

11 Sarr1[4]-"four"; 

12 Sarr1[5]-"five"; 

13 Sarr1[6]-"six"; 

14 $arr2=array(" 中 国 "," 美 国 "," 俄 罗斯 "," 英 国 "," 法 国 "); 
15 $i=5; 

16 $j; 

17 echo "数组 arr1 的 元 素 个 数 为 :"; 
18 echo count(Sarr1); 

19 echo "«p»"; 

20 echo "数组 arr2 的 元 素 个 数 为 :"; 
21 echo count($arr2); 

22 echo "<p>"; 

23 echo count($i); 

24 echo "<p>"; 

25 echo count($j); 

26 ?> 

27 </body> 

28 </html> 


在 PHP 运行 环境 中 执行 以 上 代码 ， 执 行 结果 如 图 7.21 所 示 。 


EI! 


Aa 0000 


/定义 数组 变量 1 


/定义 数组 变量 2 
/定义 变量 $i 并 赋值 
/定义 变量 $j 


// 计 算数 组 1 元 素 个 数 


// 计 算数 组 2 元 素 个 数 
// 返 回 变量 值 的 情况 
// 返 回 变量 值 的 情况 


图 7.21 计算 数组 的 元 素 个 数 实例 执行 结果 
在 PHP 中 还 有 一 个 函数 可 以 完成 类 似 的 工作 ,这 就 是 sizeof0 函 数 。 该 函数 也 是 把 数组 作为 函数 的 


参数 ， 把 数组 元 素 的 个 数 作为 函数 的 返回 值 。 因 为 这 两 个 函数 使 用 方法 相同 ， 所 以 这 里 就 不 再 介绍 。 
7.4.8 ”对 数组 排序 
GH 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 7 章 \ 对 数组 排序 .wmv 


在 实际 PHP 编程 时 ， 有 时 需要 对 数组 进行 排序 。 通常 对 数组 进行 排序 的 方法 有 冒 泡 法 、 对 分 法 等 。 


sort0 函 数 格式 如 下 : 


void sort(array array) 


但 是 在 PHP 中 对 数组 的 排序 相当 简单 ， 因 为 在 PHP 的 数组 操作 函数 中 ,有 专门 对 数组 进行 排序 的 函数 
sort() 和 rsort0。 使 用 这 两 个 函数 可 以 对 数组 进行 顺序 或 逆序 排列 。 


ROI 
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该 函数 对 数组 进行 排序 ， 使 数组 按照 从 小 到 大 的 顺序 重新 排列 。 


rsort0 函 数 格 式 如 下 : 
void rsort(array arry) 
该 函数 和 sort(0) 函 数 一 样 ， 可 对 数组 进行 排序 ， 与 sort0 函 数 不 同 的 是 ，rsort0 函 数 将 使 数组 按 从 大 
到 小 的 顺序 重新 排列 。 
【实例 7-22】 以 下 代码 演示 使 用 sort0 和 rsort() 函 数 实现 对 数组 的 排序 操作 。 
c | 实例 7-22， 使 用 sort0 和 rsort0 函 数 实 现 对 数组 的 排序 操作 
| SERE ON 
01 «html» 
02 <head> 
03 ”<title> 对 数组 排序 函数 使 用 实例 </title> 
04 </head> 
05 <body> 
06 <?php 
07 $temp-array(5,2,6,4,1,3); /定义 数组 $temp 
08 $temp1=array(" 北 京 "," 南 京 "" 上 海 "," 杭 州 "," 重 庆 "); /定义 数组 $temp1 
09 echo "数组 temp 原始 顺序 为 ;"; 
10 for($i=0;$i<count($temp);$i++) // 通 过 循环 打印 原始 数组 
11 echo $temp[Si].", "; 
12 echo "<p>"; 
13 echo "数组 temp £ sort 函数 处 理 后 的 顺序 为 :"; 
14 sort($temp); // 对 $temp 数组 进行 sort 处 理 
15 for($i=0;$i<count($temp);$i++) // 通 过 循环 打印 处 理 过 的 数组 
16 { 
ar echo $temp[$i]; 
18 echo", "; 
19 } 
20 echo "<p>"; 
21 echo "数组 temp 经 rsort 函数 处 理 后 的 顺序 为 :"; 
22 rsort($temp); /对 $temp 数组 进行 rsort 处 理 
23 for($i=0;$i<count($temp);$i++) // 通 过 循环 打印 处 理 过 的 数组 
24 { 
25 echo $temp[Si]; 
26 echo", "; 
27 H 
28 echo "<p>"; 
29 echo "一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 一 
30 echo "<p>"; 
Si echo "数组 temp1 原始 顺序 为 ;"; 
32 for($i=0;$i<count($temp1);$i++) // 通 过 循环 打印 原始 数组 
33 1 
34 echo $temp1[Si]; 
35 echo", " 
36 H 
37 echo "<p>"; 
38 echo "数组 temp1 £ sort 函数 处 理 后 的 顺序 为 : "; 
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39 sort($temp1); // 对 $temp 数组 进行 sort 处 理 
40 for($i=0;$i<count($temp1);$i++) // 通 过 循环 打印 处 理 过 的 数组 
41 ii 
42 echo $temp1[$i]; 
43 echo", "; 
44 } 
45 echo "<p>"; 
46 echo "数组 temp1 经 rsort 函数 处 理 后 的 顺序 为 : "; 
47 rsort($temp1); /对 $temp 数组 进行 rsort 处 理 
48 for($i=0;$i<count($temp1);$i++) // 通 过 循环 打印 处 理 过 的 数组 
49 IT 
50 echo $temp1[Si]; 
51 echo", "; 
52 ) 
53 ?> 
54 </body> 
55 </html> 
在 PHP 运行 环境 中 执行 以 上 代码 ， 其 执行 结果 如 图 7.22 所 示 。 
Ee] 


Qo e- O| on | 
数组 temp 原 始 顺序 为 ，5，2，6，4，1，3， 

识 组 temp 经 sor 函 数 处 理 后 的 顺序 为 ，1，2，3,，4，5，6， 

圳 组 temp 经 rson 浮 效 处 理 后 的 顺序 为 ，6，5，4,，3,，2,1， 


数组 (cmp1 原 把 顺序 


为 ; dim, 南京， 上 海 ， 杭 州 , 重庆 ， 


数组 temp]1 经 sor 国 热处理 后 的 顺序 为 ， 上 海 ， 北 京 ， 南 京 ， 访 州 ， 重 庆 . 
数组 templ1 经 rsor 范 数 处 理 后 的 顺序 为 : 重庆 ， 杭 州 ， 南 京 ， 北 京 ， 上 将 ， 


图 7.22 对 数组 排序 函数 使 用 实例 执行 结果 
通过 以 上 执行 结果 可 以 发 现 ， 在 PHP 中 对 数组 进行 排序 是 一 件 很 简单 的 事情 。 
注意 : 如 果 数组 中 数据 类 型 不 同 ， 如 何 排序 ? 


74.4 ”对 数组 进行 自 定义 排序 


有 时 , 单纯 使 用 7.4.3 节 介绍 的 sort0) 或 rsort0 函 数 均 不 能 完全 满足 对 数组 排序 的 要 求 。 如 下 面 的 数组 : 
<?php 
$temp=array(" 班 长 "," 无 职务 "," 副 班长 "," 团 支书 "); 

?> 

如 果 想 要 实现 这 样 的 排序 : 团 支 书 > 班 长 > 副 班 长 > 无 职务 .这 时 不 管 是 使 用 sort() 函 数 还 是 使 用 rsort() 
函数 ， 都 不 能 实现 。 因 为 这 种 排序 标准 是 自 定义 的 。 出 现 这 种 情况 ， 就 要 使 用 另 一 个 PHP 数组 操作 函 
数 一 一 usort() 函 数 。usort0) 函 数 的 使 用 格式 如 下 : 

void usort(array array,function cmp function) 


该 函数 用 来 对 数组 进行 排序 ， 使 数组 按照 用 户 自 定义 比较 函数 所 规定 的 顺序 重新 排列 。 
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【实例 7-23】 以 下 代码 演示 usort() 函 数 的 使 用 方法 。 


区 实例 7-23: usort() 函 数 的 使 用 方法 
b 源码 路 径 ， 光 盘 \ 源 文件 07\7-23.php 


01 <html> 

02 <head> 

03 ”<title> 对 数组 自 定义 排序 函数 使 用 实例 </title> 
04 </head> 


05 <body> 

06 <?php 

07 $temp=array(" 班 长 "," 无 职务 "," 副 班长 "," 团 支书 "," 无 职务 "," 副 班长 "); /定义 数组 Stemp 
08 function cmp($a,$b) // 自 定义 排序 函数 

09 

10 /第 一 个 参数 为 团 支书 的 情况 
11 

12 

13 return 0; 

14 elseif($b==" 班 长 ") 

15 return -1; 

16 elseif($b==" 副 班长 ") 

17 return -1; 

18 else 

19 return -1; 

20 H 

21 elseif($a==" 班 长 ) // 第 一 个 参数 为 班长 的 情况 
22 { 

23 if($b==" 团 支书 ") 

24 return 1; 

25 else if($b==" 班 长 ") 

26 return 0; 

27 else if($b==" 副 班长 ") 

28 return -1; 

29 else 

30 return -1; 

31 } 

32 elseif($a==" 副 班长 ) /第 一 个 参数 为 副 班长 的 情况 
33 { 

34 if($b==" 团 支书 ") 

35 return 1; 

36 else if($b==" 班 长 ") 

37 return 1; 

38 else if($b==" 副 班长 ") 

39 return 0; 

40 else 

41 return -1; 

42 n 

43 else /第 一 个 参数 为 无 职务 的 情况 
44 于 

45 if($b==" 团 支书 ") 

46 retum 1; 


47 else if($b==" 班 长 ") 
48 return 1; 


49 else if($b==" 副 班长 ") 

50 retum 1; 

51 else 

52 return 0; 

53 H 

54 ) /根据 不 同情 况 返 回 不 同 的 值 
55 echo "数组 temp 原始 顺序 为 :"; 

56 echo "<p>"; 

57 for($i=0;$i<count($temp);$i++) // 通 过 循环 打印 原始 数组 

58 echo $temp[$i]."，"; 

59 usort($temp,"cmp"); // 对 数组 进行 usort 处 理 

60 echo "«p»"; 

61 echo "数组 temp 经 过 usort 处 理 过 的 顺序 为 ;"; 

62 echo "<p>"; 

63 for($i-0;Si«count($temp);Si-*) /通过 循环 打印 处 理 过 的 数组 
64 echo $temp[Si].", "; 

65 ?> 

66 </body> 

67 </html> 


在 PHP 运行 环境 中 执行 以 上 代码 ， 将 会 看 到 如 图 7.23 所 示 的 执行 结果 。 
— 
OO opo 
| Büfcmo NIS ] 
Wk, ARS. ABH Hic. JOE. BUE. 
款 组 temp 经 寺 usor 处 理 过 的 顺序 为 
Bid. Hé. WIH. AIE. EES., XR. 


图 7.23 对 数组 自 定义 排序 函数 使 用 实例 执行 结果 
通过 以 上 实例 及 执行 结果 可 见 ， 使 用 usort(0) 函 数 可 以 实现 一 些 自 定义 的 排序 规则 ， 从 而 实现 对 数 
组 元 素 进行 自 定 义 排 序 。 
技巧 : 该 功能 适合 网 页 中 目录 树 的 排序 处 理 。 


74.5 “移动 数组 指针 


GEH 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 7 章 \ 移 动 数组 指针 .wmv 

经 过 前 面 的 介绍 可 以 了 解 ， 数 组 有 很 多 元 素 ， 那 么 究竟 数组 当前 元 素 是 哪 一 个 ? 这 就 需要 指出 一 
个 数组 指针 的 问题 。 每 一 个 数组 变量 都 有 一 个 内 部 指针 ， 它 指向 当前 的 数组 元 素 。 在 进行 PHP 编程 时 ， 
有 时 需要 对 数组 的 指针 进行 移动 操作 。 在 PHP 库 函 数 中 ， 有 一 组 函数 来 实现 这 一 操作 ， 介 绍 如 下 。 
current() 函 数 : 传 回 数组 当前 指针 指向 的 元 素 。 
end() 函 数 : 将 数组 的 指针 移动 到 数组 尾部 ， 即 指向 数组 最 后 的 元 素 。 
next(O) 函 数 : 将 数组 的 指针 向 后 移动 一 位 ， 即 指向 当前 的 后 一 个 元 素 。 
prev0 函 数 : 将 数组 的 指针 向 前 移动 一 位 ， 即 指向 当前 的 前 一 个 元 素 。 


回回 加 加 


(0 PHP 网 络 编程 技术 详解 


reset() 函 数 : 将 数组 的 指针 移动 到 数组 头 部 ， 即 指向 数组 的 第 一 个 元 素 。 
【实例 7-24】 以 下 代码 演示 数组 指针 操作 函数 的 使 用 方法 。 


区 实例 7-24: 数组 指针 操作 函数 的 使 用 方法 
E) 源码 路 径 : 光盘 \ 源 文件 ,07\7-24.php 


01 <html> 

02 <head> 

03 ”<title> 移 动 数组 指针 函数 使 用 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 $new[0]-"zero"; /定义 一 个 数组 以 备用 
08 $new[1]-"one"; 

09 $new[2]-"two"; 

10 $new[3]-"three"; 

11 $new[4]-"four"; 

12 $new[5]-"five"; 

13 $new[6]-"six"; 

14 for($i=0;$i<count($new);$i++) // 通 过 循环 打印 数组 
15 echo $newf[$i]."，"; 

16 echo "<p>"; 

17 echo "指针 当前 指向 : "; 

18 echo current($new); /打印 当前 数组 元 素 ， 以 确定 指针 位 置 
19 echo "<p>"; 

20 echo "指针 后 移 一 位 : "S 

21 next($new); /数组 指针 后 移 一 位 
22 echo current($new); /查看 当前 数组 指针 指向 
23 echo "<p>"; 

24 echo "指针 移动 到 尾部 : "; 

25 end($new); // 把 数组 指针 移动 到 数组 尾部 
26 echo current($new); // 查 看 是 否 已 到 尾部 
27 echo "<p>"; 

28 echo "指针 前 移 一 位 : "; 

29 prev($new); // 把 数组 指针 前 移 一 位 
30 echo current($new); // 查 看 指针 指向 情况 
31 echo "<p>"; 

32 echo "指针 移动 到 头 部 : "; 

33 reset($new); /把 数组 指针 指向 头 部 
34 echo current($new); // 查 看 是 否 已 到 头 部 
35 ?> 

36 </body> 

37 </html> 


注意 : 这 里 一 定 要 清楚 每 个 移动 数组 指针 函数 执行 后 数组 指针 的 位 置 。 


在 PHP 运行 环境 执行 以 上 代码 ， 执 行 结果 如 图 7.24 所 示 。 
下 面 对 以 上 代码 及 执行 结果 做 一 简单 分 析 : 首先 初始 化 数组 ， 数 组 指针 指向 数组 第 一 个 元 素 ， 所 
以 current(O) 函 数 返 回 数组 的 第 一 个 元 素 zero: 指针 后 移 一 位 则 指向 one; 指针 移动 到 数组 的 尾部 则 指向 
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最 后 一 个 元 素 six; 指针 前 移 一 位 则 指向 five; 指针 移动 到 头 部 则 指向 zero. 


用 指针 移动 到 头 部 ，zero 


E724 移动 数组 指针 函数 使 用 实例 执行 结果 
7.4.6 ”获取 数组 当前 元 素 


(I 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 7 章 \ 获 取 数 组 当前 元 素 .wmv 
通过 7.4.5 节 对 PHP 中 移动 数组 指针 函数 的 介绍 可 知 ， 要 获得 数组 当前 元 素 ， 可 以 使 用 的 方法 就 
是 使 用 current0 函 数 。 其 格式 如 下 : 


mixed current(array array) 
该 函数 的 返回 值 即 为 当前 数组 指针 指向 的 元 素 。 
注意 : 还 有 一 个 posO) 函 数 ， 此 函数 是 current() 函 数 的 别名 ， 两 个 函数 具有 相同 的 参数 、 作 用 及 返回 值 。 
通过 两 个 函数 都 可 以 获得 数组 当前 的 元 素 。 


7.4.7 ” 移 去 数组 中 重复 的 值 


(D 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 7 章 \ 移 去 数组 中 重复 的 值 .wmv 

如 果 一 个 数组 中 有 大 量 的 数据 ， 在 进行 数组 处 理 时 ， 将 其 重复 、 宛 余数 据 的 值 移 除 就 显得 很 有 必 
要 。 因 为 这 样 可 以 减少 数据 量 ， 从 而 加 快 数据 的 处 理 速度 。 在 PHP 中 有 一 个 函数 可 以 移 去 数组 中 重复 
的 值 ， 这 个 函数 就 是 array_unique()。 其 格式 如 下 : 

array array unique(array array) 


array_unique() 函 数 用 于 移 去 数组 中 重复 的 值 。 该 函数 将 数组 参数 array 中 重复 的 值 移 除 ， 将 处 理 过 
的 新 数组 作为 函数 的 返回 值 返回 。 
【实例 7-25】 以 下 代码 演示 array_uniqueO 函 数 的 使 用 方法 。 


€ 实例 7-25: aray_unique() 函 数 的 使 用 方法 
源码 路 径 : 光盘 \ 源 文件 \07\7-25.php 


02 <head> 

03 ”<title> 移 去 数组 中 重复 的 值 函 数 使 用 实例 </title> 
04 </head> 

05 <body> 

06 <?php 


网 络 编程 技术 详解 


07 $new[0]-"zero"; /定义 一 个 数组 以 备用 
08 $new[1]-"one"; 

09 $new[2]-"zero"; 

10 $new[3]-"three"; 

11 $new[4]-"zero"; 

12 $new[5]-"five"; 

13 S$new[6]-"six"; 

14 for($i=0;$i<count($new);$i++) // 通 过 循环 打印 数组 
15 echo $newf$i]."，"; 

16 echo "«p»"; 

17 $new1-array unique($new); // 对 数组 进行 去 除 重复 值 处 理 
18 for($i=0;$i<count($new1);$i++) // 通 过 循环 打印 新 数组 
19 echo $new1[Si].", "; 

20 ?> 

21 </body> 

22 </html> 

在 PHP 运行 环境 中 执行 以 上 代码 ， 其 执行 结果 如 图 7.25 所 示 。 


[< 全 EEC 


i 
zero, one, zero, three, zero, five, six, | 


zero, one. , three. . 


图 7.25 移 去 数组 中 重复 的 值 函数 使 用 实例 执行 结果 
查看 以 上 代码 及 执行 结果 可 见 , 使 用 array_unique() 函 数 对 数组 进行 操作 , 移 去 了 数组 中 重复 的 值 。 


注意 : 在 使 用 array_unique() 函 数 时 ， 虽 然 去 除了 数组 中 的 重复 值 ， 但 数组 的 键 名 仍 将 保持 不 变 。 从 以 
上 执行 结果 中 就 可 以 看 出 ，$new1[0]、S$new1[2] 的 值 为 空 值 但 其 键 名 仍 在 。 


74.8 计算 数组 中 所 有 值 出 现 的 次 数 


做 1 知识 点 讲解 :光盘 \ 视 频 讲解 第 7 章 \ 计 算数 组 中 所 有 值 出 现 的 次 数 .wmv 

在 使 用 数组 时 ， 如 果 一 个 数组 中 有 一 个 或 几 个 值 重复 出 现 ， 那 么 统计 数组 中 值 的 出 现 次 数 也 是 很 
有 必要 的 。 例 如 ， 将 一 个 班级 所 有 学 生 的 年 龄 赋值 给 数组 ， 计 算 某 个 年 龄 的 学 生 有 几 人 的 情况 。 这 时 
就 要 用 到 PHP 数组 操作 函数 array_count_values()。 其 格式 如 下 : 


array array_count_values(array array) 


该 函数 用 于 统计 数组 中 所 有 值 出 现 的 次 数 。 此 函数 返回 一 个 数组 ， 该 数组 用 参数 数组 中 的 值 作为 
键 名 ， 用 参数 数组 中 该 值 出 现 的 次 数 作为 值 。 
【实例 7-26】 以 下 代码 演示 使 用 array_count_values0 函 数 计算 数组 中 所 有 值 出 现 的 次 数 。 


re 实例 7-26: 使 用 array_count_values() 函 数 计算 数组 中 所 有 值 出 现 的 次 数 
源码 路 径 : 光盘 \ 源 文件 \07\7-26.php 


01 <html> 
02 <head> 
03 ”<title> 计 算数 组 中 所 有 值 出 现 的 次 数 函 数 使 用 实例 </title> 
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04 </head> 

05 <body> 

06 <?php 

07 $new[0]="zero"; /定义 一 个 数组 以 备用 
08 $new[1]="one"; 

09 $new[2]-"zero"; 

10 $new[3]-"zero"; 

11 $new[4]-"one"; 

i 区 S$new[5]-"two"; 

13 S$new[6]-"zero"; 

14 for($i=0;$i<count($new);$i++) // 通 过 循环 打印 数组 
15 echo $new[Si].", "; 

16 echo "<p>"; 

17 $new1-array count values($new); /使 用 array_count_values() 函 数 进行 处 理 
18 echo "zero 出 现 的 次 数 为 :"; 

19 echo $new1["zero"]; // 打 印 zero 出 现 的 次 数 
20 echo "<p>"; 

21 echo "one 出 现 的 次 数 为 : "| 

22 echo $new1["one"]; /打印 one 出 现 的 次 数 
23 echo "<p>"; 

24 echo "two 出 现 的 次 数 为 :"; 

25 echo $new1["two"]; // 打 印 two 出 现 的 次 数 
26057» 

27  «lbody» 

28 </html> 


在 PHP 运行 环境 中 执行 以 上 代码 ， 其 执行 结果 如 图 7.26 所 示 。 


zero, one, zero, zero, 
zero 出 现 的 次 数 为 : 4 
one 出 现 的 次 数 为 ，2 
wo 出 现 的 次 数 为 ，1 


图 7.26 计算 数组 中 所 有 值 出 现 的 次 数 函 数 使 用 实例 执行 结果 
查看 以 上 代码 及 执行 结果 可 见 ,通过 array. count. values() 函 数 返 回 了 原 数组 中 的 值 及 值 出 现 的 次 数 
作为 新 数组 ， 从 而 实现 了 对 数组 中 值 出 现 次 数 的 统计 。 
技巧 : 该 功能 适合 实现 简易 的 投票 统计 功能 。 


749 合并 多 个 数组 


GH 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 7 章 \ 合 并 多 个 数组 .wmv 

实际 进行 PHP 编程 时 ， 对 多 个 相关 或 者 类 型 相同 的 数组 进行 操作 ， 其 复杂 程度 要 远 比 对 一 个 数组 
进行 操作 大 得 多 。 所 以 ， 如 果 能 把 多 个 数组 合并 为 一 个 数组 ， 就 能 起 到 简化 操作 的 目的 。 库 函数 丰富 
的 PHP 编程 环境 也 为 用 户 准备 了 这 样 的 函数 ， 这 个 函数 就 是 aray_merge()， 其 原型 如 下 : 


array array_merge(array array1,array array2,array array3…) 


KA aaa 


array_merge() 函 数 将 作为 函数 参数 的 多 个 数组 进行 合并 。 一 个 数组 中 的 值 附加 在 前 一 个 数组 后 面 ， 
合并 后 的 新 数组 作为 函数 的 返回 值 。 
在 使 用 此 函数 时 有 一 点 需要 注意 ， 如 果 两 个 数组 中 存在 相同 的 字符 键 名 ， 那 么 后 一 个 数组 中 的 同 


键 名 的 值 ， 将 替换 前 一 个 数组 中 相应 元 素 的 值 。 如 : 
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$a=array(a=>"a",b=>"b",c=>"c"); 
$b=array(a=>"d",b=>"e",c=>"f"); 
对 以 上 两 个 数组 进行 合并 ， 数 组 $b 中 的 元 素 $b[a]、$b[b]、S$b[c] 将 替代 数组 $a 中 相应 的 元 素 。 

如 果 是 相同 的 数字 键 值 ， 并 不 会 出 现 这 样 的 操作 ， 即 后 一 个 数组 的 值 蔡 换 前 一 个 数组 中 的 值 。 如 : 
$a=array("a","b","c"); 
S$bzarray("d","e" "f"); 
对 这 两 个 数组 进行 合并 ， 因 为 它们 都 是 以 数字 作为 键 值 ， 如 $a[0]="a"、$b[0]="d"、…、$a[2]="e"、 
$b[2]="f'。 这 样 的 合并 不 会 出 现 值 蔡 代 的 情况 。 数 组 $b 中 的 元 素 将 作为 新 的 元 素 加 入 到 新 合并 的 数 
组 中 。 


【实例 7-27】 以 下 代码 演示 array_merge() 函 数 的 使 用 方法 。 


<head> 

<title> 合 并 多 个 数组 函数 使 用 实例 </title> 
</head> 

<body> 

<?php 


$a=array(1,2,3,4,5,6); 
$b=array(7,8,9,10,11); 
echo "数组 a 的 内 容 为 :"; 
for($i=0;$i<count($a);$i++) 
echo $a[$i]."，"; 
echo "<p>"; 
echo "数组 b 的 内 容 为 :"; 
for($i=0; $i<count($b);$i++) 
echo $b[$i].", "; 
echo "<p>"; 
S$c-array, merge($a,$b); 
echo "合并 后 的 数组 CHAZA: " 
for($i=0;$i<count($c):$i++) 


echo $c[Si].", "; 
echo "«p»"; 
S$str1-array( 
"name'-»"s E", 
'sex-»" F", 
"length'z2"170CM" 
y 
S$str2-array( 


实例 7-27: array_merge() 函 数 的 使 用 方法 
源码 路 径 ， 光盘 \ 源 文件 \07\7-27.php 


// 定 义 数组 $a 
// 定 义 数组 $b 


/循环 打印 数组 $a 


/| 循环 打印 数组 $b 


// 对 两 个 数组 进行 合并 


// 循 环 打 印 合并 后 的 数组 


/定义 数组 $str1 


28 mame'=>" 李 四 "， 


29 'birthday'=>"5 月 13 &", 

30 'length'=>"175CM" 

31 JE /定义 数组 $str2 

32 echo "数组 str1 的 内 容 为 : "; 

33 print. r(Sstr1); /格式 化 显示 $str1 的 内 容 
34 echo "<p>"; 

35 echo "数组 str2 的 内 容 为 : "; 

36 print r($str2); /格式 化 显示 $str2 的 内 容 
37 $str3-array merge(Sstr1,$str2); // 对 两 个 数组 进行 合并 

38 echo "<p>"; 

39 echo "合并 后 的 数组 str3 的 内 容 为 :"; 

40 print_r($str3); /格式 化 显示 合并 后 的 数组 
41 2? 

42 </body> 

43 «html» 


在 PHP 运行 环境 中 执行 以 上 代码 ， 其 执行 结果 如 图 7.27 所 示 。 


[ENSIS] 
[€] E iie //localhost/7-27 pho D ~ Ò | Bazsomsama | e 
[mies 1 2.3. 4. 5. 6 

数组 b 的 内 容 为 ，7，8，9，10，11， 

全 并 后 的 数组 < 的 内 容 为 ， 1，2，3，4，5，6，1，8，9%， 10, 11, 
|| 数组 strl 的 内 容 为 ，Armay ( [name] 一 张 三 [sex] => $ [length] > 170CM ) 


效 组 st 的 内 容 为 ，Ammay ( [name] 一 李 四 [birthday] > 5 138 [length] => 175CM) 
|| SHERR AAEH. Array ( [name] >EN [ex] length) 一 175CM [hinhdy] 一 5138 ) 


图 7.27 合并 多 个 数组 函数 使 用 实例 执行 结果 


查看 以 上 实例 及 执行 结果 可 见 ， 通 过 array_merge() 函 数 将 多 个 数组 进行 了 合并 ， 并 且 遵 循 这 样 的 
规则 : 新 的 字符 键 值 的 值 蔡 换 以 前 的 字符 键 值 的 值 ， 而 数字 键 值 的 值 只 作为 新 值 累 加 。 


7.4.10 ”其 他 常用 数组 函数 


EH 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 7 章 \ 其 他 常用 数组 函数 .wmv 

在 实际 使 用 PHP 进行 网 络 编程 的 过 程 中 ,除了 以 上 介绍 的 数组 操作 函数 之 外 ,还 有 一 些 常用 的 PHP 
数组 函数 。 由 于 这 些 函数 使 用 频率 相对 于 前 面 介 绍 的 函数 较 低 ， 所 以 只 作 简 单 介 绍 。 

bool in_array() 函 数 : 

bool in array(mixed needle, array haystack [, bool strict]) 

该 函数 在 haystack 中 搜索 needle， 如 果 找 到 则 返回 True， 否 则 返回 False. 

bool ksort() FK Žít: 

bool ksort(array &array [, int sort flags]) 

该 函数 对 数组 的 键 名 进行 排序 ， 保 留 键 名 到 数据 的 关联 。 

bool natcasesort() 函 数 : 


M aaa 


bool natcasesort(array &array) 

该 函数 用 自然 排序 法 〈 即 按照 从 小 到 大 的 顺序 进行 排序 ) ， 对 数组 进行 不 区 分 大 小 写字 母 的 排序 ， 
并 把 结果 作为 函数 返回 值 。 

PHP 中 常用 的 数组 函数 就 介绍 到 这 里 ， 如 果 想 要 学 习 更 多 的 内 容 ， 请 参考 相关 手册 。 


75 本 章 小 结 


本 章 介绍 了 PHP 的 数据 处 理 ,包括 PHP 中 常用 的 数学 函数 、 字 符 串 处 理 函 数 、 数 组 处 理 函 数 等 内 
容 。 熟 练 掌握 这 些 函 数 对 数据 的 操作 ， 将 在 实际 的 编程 工作 中 起 到 事半功倍 的 效果 。 数 据 处 理 是 编写 
大 型 Web 应 用 程序 的 基础 ， 只 有 正确 地 对 数据 进行 相应 的 处 理 ， 才 能 为 大 型 应 用 程序 提供 数据 基础 
支持 。 


7.6 本 章 习 题 


习题 7-1 使 用 rand0 函 数 生 成 1 一 100 之 间 的 随机 数 并 输出 。 
【分 析 】 该 习题 考查 读者 对 rand0 函 数 的 掌握 情况 。 
【关键 代码 】 
echo rand(1,100); 
习题 7-2 ”使 用 strlen0) 函 数 获取 如 下 字符 串 的 长 度 并 输出 该 长 度 。 
What are you doing? 
【分 析 】 该 习题 考查 读者 对 strlen() 函 数 使 用 方法 的 掌握 。 
【关键 代码 】 


Slen=strlen("What are you doing? "); 
echo $len; 


习题 7-3 ”使 用 count() 函 数 计算 如 下 数组 元 素 的 个 数 。 
array(array[1,2],array(3,4,5),array(6,0)) 
【分 析 】 该 习题 主要 考查 读者 对 count() 函 数 的 掌握 。 
【关键 代码 】 
count(array(array(1,2),array(3,4,5),array(6,0))); 
习题 7-4 ”使 用 sort0) 函 数 对 如 下 数组 进行 排序 。 
array(4,9,45,21,78,25,33) 
【分 析 】 该 习题 主要 考查 读者 对 sort() 函 数 的 掌握 。 
【关键 代码 】 


e. 


Sarr-array(4,9,45,21,78,25,33); 
sort(Sarr); 


2]88 7-5 (EH next0 和 curren() 函 数 输出 如 下 数组 中 的 21. 
array(4,9,45,21,78,25,33) 


【分 析 】 该 习题 主要 考查 读者 对 移动 数组 指针 函数 的 掌握 。 
【关键 代码 】 


$arr=array(4,9,45,21,78,25,33); 
next($arr); 

next($arr); 

next($arr); 

echo current($arr); 


$85 PHP 文件 应 用 


文件 操作 在 PHP 编程 中 占有 重要 的 地 位 。 在 很 多 情况 下 都 要 对 文件 进行 操作 ， 如 文本 计数 器 、 文 
本 留言 板 、 文 件 管理 系统 甚至 是 文本 数据 库 等 。 本 章 将 详细 介绍 在 PHP 中 如 何 判 断 文件 是 否 存 在 、 如 
何 获取 文件 属性 、 如 何 读 取 文件 内 容 、 如 何 对 目录 进行 读 取 等 操作 。 通 过 本 章 的 学 习 ， 读 者 将 对 使 用 
PHP 进行 操作 文件 有 一 个 全 面 的 认识 。 


81 判断 文件 是 否 存 在 


(E 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 8 章 \ 判 断 文件 是 否 存在 .wmv 

在 对 一 个 文件 进行 操作 之 前 ， 判 断 该 文件 是 否 存 在 是 有 必要 的 。 如 果 打开 一 个 并 不 存在 的 文件 ， 
就 会 导致 错误 。 在 PHP 中 有 一 个 专门 的 函数 来 做 这 一 项 工作 ， 这 个 函数 就 是 file_exists(string) 函 数 。 参 
数 string 为 一 个 指向 文件 或 目录 的 字符 型 变量 ， 函 数 的 返回 值 为 布尔 型 变量 ， 即 如 果 文 件 或 目录 存在 ， 
返回 值 为 True， 反之 则 返回 Falses 


【实例 8-1】 以 下 代码 演示 使 用 file_exists() 函 数 判断 一 个 文件 是 否 存 在 。 


K | 实例 8-1 使 用 file_exists0 函 数 判断 一 个 文件 是 否 存在 


源码 路 径 ， 光盘 源 文件 08W8-1.pbp 


<head> 
<title>file_exists() 函 数 使 用 实例 </title> 
</head> 
<body> 
<?php 
$filename-"data.txt"; /定义 变量 
if(file exists(Sfilename)) // 如 果 文件 存在 时 执行 操作 
echo "指定 文件 ".$filename." 存 在 "; 
else // 如 果 文件 不 存在 时 执行 操作 
echo "指定 文件 ".$filename." 不 存在 !"; 
?> 
</body> 
</html> 


在 PHP 运行 环境 中 执行 该 PHP 文件， 如 果 在 该 程序 同名 目录 下 有 data.txt 文件 则 会 返回 “文件 存 


$E" i 
使 用 的 。 


否则 会 返回 “文件 不 存在 ”。 通 过 上 面 的 实例 ， 读 者 可 以 清晰 地 认识 到 file_exists0 函 数 是 如 何 


注意 : 基于 安全 考虑 ， 大 多 数 的 文件 操作 类 函数 的 文件 名 参数 不 能 为 远程 文件 ， 即 只 能 通过 服务 器 的 


ssa OMPESER KA 


文件 系统 访问 。 其 中 包括 本 节 的 file_exists0) 函 数 及 8.2 节 将 要 介绍 的 函数 。 例 如 这 样 的 引用 : 
file exists("http://www.sohu.com/index.mdb") (其 实 并 不 存在 该 文件 ) ， 不 论文 件 存在 与 否 都 将 
返回 False。 


8.2 访问 文件 属性 
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在 进行 编程 时 ， 需 要 使 用 到 文件 的 一 些 常见 属性 ， 如 文件 的 大 小 、 文 件 的 类 型 、 文 件 的 修改 时 间 、 
文件 的 访问 时 间 、 文 件 的 权限 等 。 通 过 本 节 的 学 习 ， 读 者 会 发 现 使 用 PHP 的 相关 函数 获取 文件 属性 是 


Ea 


filesize(string) 


filetype(string) 


filemtime(string) 


fileatime(string) 


R81 文件 属性 相关 函数 


ft 用 参数 及 返回 值 
参数 string 为 一 个 指向 文件 或 目录 的 字符 型 变量 ， 函 数 的 返回 值 为 整 型 变量 ， 
回 文件 的 大 小 〈 字 节 ) 。 如 果 出 错 则 返回 False。 函 数 参数 不 能 为 远程 文件 ， 
返回 结果 会 被 缓存 
获取 文件 的 类 型 参数 string 为 - -个 指向 文件 或 目录 的 字符 型 变量 ， 函数 的 返回 值 为 字符 型 变量 ， 可 
E 出 现 的 值 有 fifo, char, dir, block, link, file 和 unknown， 返 回 值 会 被 缓存 
获取 文件 的 修改 | 参数 string. 为 一 个 指向 文件 或 目录 的 字符 型 变量 ， 函 数 的 返回 值 为 整 型 变量 ， 
时 间 返回 文件 的 修改 时 间 
获取 文件 的 访问 | 参数 string 为 一 个 指向 文件 或 目录 的 字符 型 变量 ， 返 回 值 为 整 型 变量 ， 内 容 为 
时 间 文件 的 访问 时 间 
参数 string 为 一 个 指向 文件 或 目录 的 字符 型 变量 ， 返 回 值 为 整 型 变量 ， 内 容 为 


获取 文件 的 大 小 


Dd 


um 


fileperms(string) | 获取 文件 的 权限 | 文件 相应 的 权限 ， 同 其 他 这 一 类 型 的 函数 一 样 ， 参 数 不 能 为 远程 文件 ， 另 外 返 


回 结果 同样 会 被 缓存 


【实例 8-2】 以 下 代码 演示 使 用 表 8.1 中 的 函数 获取 文件 的 属性 。 


<head> 

<title> 访 问 文件 属性 函数 使 用 实例 </title> 
</head> 

<body> 

<?php 


Sfilename-"data.txt"; /定义 变量 

echo $filename." 的 大 小 为 :" filesize($filename)."<br>"; /使 用 filesize() 函 数 
echo $filename." 的 类 型 为 :" .filetype($filename)."<br>"; IH FB filletype() 函 数 
/使 用 filemtime() 函 数 并 格式 化 返回 日 期 

echo $filename." 的 修改 时 间 为 : ".date("Y 年 n 月 t 日 "filemtime($filename))."<br>"; 
// 使 用 fileatime() 函 数 并 格式 化 返回 日 期 

echo $filename." 的 访问 时 间 为 : ".date("Y Æ n H t R" fileatime($filename))."<br>"; 


KI 


(000 ea 


14 /使 用 fileperms() 函 数 

15 echo $filename." 的 权限 为 :".fileperms($filename)."<br>"; 
16 ?> 

17 </body> 

18 </html> 


注意 : 在 使 用 这 个 例子 之 前 ， 要 保证 同 级 目录 下 有 data.txt 文 件 。 


在 PHP 运行 环境 中 执行 以 上 代码 ， 执 行 结果 如 图 8.1 Bras (当然 会 因为 文件 data.txt 的 不 同 ， 得 出 
结果 有 所 不 同 ) 。 


图 8.1 访问 文件 属性 函数 使 用 实例 执行 结果 
读者 从 这 个 实例 中 能 够 认识 到 ， 使 用 PHP 文件 相关 函数 获得 文件 属性 ， 是 一 件 很 简单 的 事情 。 


83 打开 文件 


要 使 用 一 个 文件 ,第 一 件 事 就 是 要 把 文件 打开 .PHP 中 提供 了 一 个 很 有 用 的 库 函 数 :fopen(string file , 
string mode)， 它 的 作用 就 是 打开 本 地 或 者 远程 文件 。 参 数 flename 为 一 个 字符 型 变量 ， 代 表 想 要 打开 
文件 的 名 称 ; 参数 mode 为 打开 模式 ， 可 选 的 参数 有 以 下 6 个 ,分别 是 r、r+、w、w+、a、at+。 根 据 所 
选 参数 的 不 同 ， 又 可 以 分 为 下 面 将 要 介绍 的 几 种 不 同 的 打开 类 型 。 


8.3.1 用 只 读 方 式 打开 文件 


GE 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 8 章 \ 用 只 读 方式 打开 文件 .wmv 

用 只 读 方 式 打 开 文件 使 用 ，fopen(string file,"r")。 参 数 r 使 打开 模式 为 只 读 ， 文 件 指针 指向 文件 开 
头 处 。 这 样 打开 的 文件 ， 不 能 被 写 入 。 

【实例 8-3】 以 下 代码 演示 使 用 fopen() 函 数 以 只 读 方式 打开 文件 。 


re 实例 8-3. 使 用 fopen() 函 数 以 只 读 方式 打开 文件 
源码 路 径 : 光盘 \ 源 文件 \08\8-3.php 


02 <head> 

03 ”<title>fopen() 函 数 使 用 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 Sfilename-"data.txt"; /定义 变量 


zsa PHP 文 件 应 AA 


08 /使 用 fopen() 函 数 打开 文件 
09 // 并 且 使 用 “r” 参 数 设置 打开 模式 为 只 读 


10 $myfile-fopen($filename,"r"); 

11 fwrite($myfile,"hello world!"); // 试 图 进行 写 入 操作 
12 fclose($myfile); /关闭 打开 的 文件 
13 ?> 

14 </body> 

15 </html> 


在 PHP 运行 环境 中 执行 以 上 代码 ， 会 发 现 fwrite) 〈 对 文件 进行 写 入 操作 ) 这 一 句 并 没有 被 执行 。 
打开 文件 data.txt 会 发 现 ， 里 面 也 并 没有 多 出 “hello world!” 这 个 字符 串 。 这 是 因为 Smyfile 句柄 的 打开 
方式 为 只 读 ， 所 以 不 能 进行 写 入 操作 。 


83.2 用 写 入 方式 打开 文件 
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用 写 入 方式 打开 文件 ，fopen(string file,"w")、fopen(string file,"a")。 参 数 w、a 使 打开 模式 为 写 入 ， 
这 样 打开 的 文件 能 够 被 写 入 。 另 外 ， 使 用 这 两 个 参数 ， 当 文件 不 存在 时 ， 能 自动 创建 文件 。 两 者 的 不 
同 在 于 ， 使 用 参数 w 使 文件 指针 指向 文件 开始 处 并 将 原文 件 清空 《所 以 这 是 一 个 很 危险 的 参数 ， 除 非 
认为 原来 的 内 容 没 用 了 ， 和 否则 不 要 使 用 此 参数 ) ; 而 使 用 参数 a 使 文件 指针 指向 文件 结尾 而 且 不 会 清 
空 原文 件 内 容 。 

【实例 8-4】 以 下 代码 演示 使 用 fopen() 函 数 以 写 入 方式 打开 文件 。 

区 "1" | 实例 84， UE fopenQ BRONS ANTICI 

b WR: 光盘 \ 源 文件 \08\8-4.php 


02 <head> 

03 ”<title>fopen() 函 数 使 用 实例 2</title> 

04 </head> 

05 <body> 

06 <?php 

07 Sfilename-"data.txt"; /定义 变量 
08 // 使 用 fopen() 函 数 打开 文件 

09 // 并 且 使 用 “w ”参数 设 置 打开 模式 为 写 入 


10 $myfile=fopen($filename,"w"); 

11 fwrite($myfile,"hello world!"); // 试 图 进行 写 入 操作 
12 fgets($myfile,255); // 进 行 读 取 操作 
13 fclose($myfile); /关闭 打开 的 文件 
14 ?> 

15 </body> 

16 «/html» 


在 PHP 运行 环境 中 执行 以 上 代码 ， 然 后 打开 文件 data.txt 会 发 现 ， 里 面 多 出 了 “hello world!” 这 个 
字符 串 ， 说 明 fwrite() 这 人 句 对 文件 进行 写 入 操作 的 语句 被 执行 了 。 但 是 以 写 入 方式 打开 的 文件 只 能 被 写 
入 而 不 能 通过 feetc()、fgets() 等 函数 来 读 取 文件 的 内 容 。 如 上 例 中 的 名 ets0 语 句 就 没有 被 顺利 执行 。 

通过 这 两 个 实例 ， 相 信 读 者 对 文件 的 只 读 与 只 写 这 两 种 不 同 的 打开 方式 会 有 深刻 体会 。 


(0 PHP 网 络 编程 技术 详解 


8.5.3 用 读 写 方式 打开 文件 
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用 读 写 方式 打开 文件 可 以 有 3 种 形式 : fopen(string file,"r+")、fopen(string file,"w+") 和 fopen(string 
file,"a-"). 3 r+、w+、a+ 使 打开 模式 为 读 写 ， 这 样 打开 的 文件 ， 既 能 够 被 读 取 也 能 够 被 写 入 。 但 是 
3 个 参数 也 是 有 所 不 同 的 : 

参数 r+ 使 文件 指针 指向 文件 开头 。 

回 ”参数 w+ 使 文件 指针 指向 文件 末尾 并 清空 原文 件 。 

参数 a+ 与 w+ 基本 类 似 ， 不 同 的 是 它 并 不 清空 原文 件 。 

【实例 8-5】 以 下 代码 演示 使 用 fopen() 函 数 以 读 写 方式 打开 文件 。 


实例 8-5: 使 用 fopen0 函 数 以 读 写 方式 打开 文件 
源码 路 径 光盘 \ 源 文件 \08\8-5.php 


01 
02 <head> 

03 ”<title>fopen() 函 数 使 用 实例 3</title> 

04 </head> 

05 <body> 

06 <?php 

07 S$filename-"data.txt"; // 定 义 变量 
08 // 使 用 fopen() 函 数 打开 文件 

09 // 并 且 使 用 r+ 参数 设置 打开 模式 为 读 写 


10 $myfile=fopen($filename, "r+"); 

11 fwrite($myfile,"hello world!"); // 试 图 进行 写 入 操作 
12 fgets($myfile,255); /进行 读 取 操 作 

13 fclose($myfile); /关闭 打开 的 文件 
14 ?> 

15 </body> 

16 </html> 


在 PHP 运行 环境 中 执行 以 上 代码 ， 然 后 打开 文件 data.txt 会 发 现 ， 里 面 多 出 了 “hello world!” 这 个 
字符 串 ， 说 明 对 文件 的 写 入 操作 被 正确 执行 。 下 面 通过 表 8.2 来 说 明 这 6 个 参数 的 异同 。 
X82 文件 打开 方式 的 异同 


$ 5H 
读 写 方式 DE] 读 写 
指针 位 置 n XE 文件 尾 
是 否 清空 原文 件 内 容 否 


文件 不 存在 时 是 否 创建 | E 


84 读 取 文件 内 容 


打开 文件 后 就 要 读 取 文 件 的 内 容 了 ，PHP 的 文件 函数 提供 了 多 种 方法 来 完成 这 一 任务 。 有 读 取 单 
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个 字符 的 fgetc() 函 数 、 读 取 文 件 一 行 信息 的 feets(O) 函 数 、 读 取 整 个 文件 内 容 的 file() 函 数 等 。 本 节 将 详 
细 介 绍 在 PHP 编程 环境 中 如 何 读 取 文 件 内 容 。 在 介绍 本 节 内 容 之 前 , 首先 在 有 PHP 运行 权限 的 目录 内 
建立 data.txt 文件 ， 并 输入 以 下 内 容 : 


«html» 

<head> 

<title> 读 取 文 件 内 容 </title> 
</head> 

<body> 

读 取 文 件 内 容 


<p> 

<u> 读 取 文 件 内 容 </u> 
</body> 

</html> 


84.1 ” 读 取 文件 相应 字符 
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如 果 只 读 取 一 个 文件 中 的 某 一 个 字符 ， 使 用 fgetc(int fp) 函 数 是 很 方便 的 。 该 函数 的 参数 fp 是 已 经 
被 打开 的 文件 句柄 , 函数 返回 当前 文件 指针 所 指向 的 字符 。 如 果 文 件 指针 指向 文件 末尾 ， 则 返回 Falses 

【实例 8-6】 以 下 代码 演示 使 用 feetc() 函 数 读 取 文件 中 的 一 个 字符 。 


02 <head> 

03 ”<title>fgetc() 函 数 使 用 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 // 打 开 文件 的 同时 读 取 文 件 指针 指向 的 字符 

08 $myfile=fopen("data.txt","r"); /用 只 读 打开 文件 ， 文 件 指针 指向 文件 开头 
09 $mychar=fgetc($myfile); /用 fgetc() 函 数 读 取 文 件 指针 处 字符 并 赋值 给 变量 
10 echo $mychar; UE 

11 fclose($myfile); /关闭 打开 的 文件 

Ls te 

13 </body> 

14 «html» 


在 PHP 运行 环境 中 执行 以 上 代码 ， 将 返回 <。 因 为 文件 指针 指向 文件 头 ， 指 针 处 内 容 赋 值 给 变量 。 
【实例 8-7】 以 下 代码 演示 使 用 他 etc0 函 数 通 过 循环 读 取 文件 所 有 内 容 。 


re 实例 8-7: 使 用 fgetc0 函 数 通 过 循环 读 取 文件 所 有 内 容 
源码 路 径 光盘 \ 源 文件 \08\8-7.php 


01 <html> 
02 <head> 


KA ea 


03 ”<title>fgetc() 函 数 使 用 实例 2</tite> 


04 </head> 

05 <body> 

06 <?php 

07 // 通 过 循环 读 取 文 件 所 有 内 容 
08 $myfile-fopen("data.txt","r"); 
09 while(!feof($myfile)) 

10 { 

11 $mychar=fgetc($myfile); 
12 echo $mychar; 

13 ) 

14 fclose($myfile); 

152?» 

16 </body> 

17 </html> 


/用 只 读 打 开 文 件 ， 文 件 指针 指向 文件 开头 
/通过 循环 判断 指针 是 否 指向 文件 末尾 


WA fgetc() 函 数 读 取 文件 指针 处 字符 并 赋值 给 变量 
// 显 示 变 量 


// 关 闭 打开 的 文件 


在 PHP 运行 环境 中 执行 该 代码 ， 执 行 结果 如 图 8.2 所 示 。 


图 8.2 ”人 eetc() 函 数 使 用 实例 执行 结果 
查看 打开 页 面 的 源 文件 ， 会 发 现 内容 与 data.txt 文件 完全 一 样 ， 这 就 说 明文 件 内 容 被 正确 读 取 。 这 


里 顺便 提 一 下 feof() 函 数 ， 它 的 作用 就 是 判断 文件 指针 


尾 返 回 True， 反 之 则 返回 False. 
84.2 按 行 返 回 文件 内 容 


是 否 指向 文件 未 尾 ， 如 果 已 经 指向 或 超过 文件 未 
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如 果 需 要 按 行 读 取 文件 内 容 ， 就 使 用 fgets(int fp,inb 函 数 。 和 fgetc0 函 数 一 样 ，fp 参数 是 已 经 被 打 
开 的 文件 句柄 , 第 二 个 int 参数 为 要 读 取 字 符 的 个 数 。 函 数 返 回 当前 文件 指针 所 指向 行 指定 的 字符 个 数 。 


如 果 文 件 指针 指向 文件 末尾 ， 则 返回 False. 


【实例 8-8】 以 下 代码 演示 使 用 fgets0 函 数 读 取 文件 中 的 一 行内 容 。 


re | KB 8-8: 使 用 feets() 函 数 读 取 文 件 中 的 一 行内 容 


源码 路 径 : 光盘 \ 源 文件 \08\8-8.php 


02 <head> 

03 ”<title>fgets() 函 数 使 用 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 // 打 开 文 件 的 同时 读 取 文件 指针 指向 的 行 
08 $myfile-fopen("data.txt","r"); 

09 $myline-fgets($myfile,255); 


/用 只 读 打开 文件 ， 文 件 指针 指向 文件 开头 
// 用 fgets() 函 数 读 取 文件 指针 所 在 行 并 赋值 给 变量 


ssa MPESER 0000 


10 echo $myline; /显示 变量 

11 fclose($myfile); /关闭 打开 的 文件 
(12457 

13 </body> 

14 </html> 


在 PHP 运行 环境 中 执行 以 上 代码 ， 会 发 现 什么 也 没有 ， 但 查看 源 文件 会 发 现 “<html>”。 因 为 文 
件 指 针 指 向 文件 头 ， 指 针 指向 的 行为 第 一 行 即 “<html>” 赋 值 给 了 变量 。 同 fgetc0) 函 数 一 样 ， 全 ets() 
函数 也 可 以 通过 循环 来 实现 显示 文件 全 部 内 容 ， 这 里 不 再 袭 述 。 


8.4.3 按 行 返回 文件 内 容 并 去 除 HTML 标记 
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有 时 返回 文件 指定 行内 容 的 同时 需要 去 除 掉 HTML 标记 ， 这 时 使 用 fgetss(int 印 ,inb) 函 数 就 很 方便 
了 。 函 数 使 用 方法 与 fgets() 相 同 ， 不 同 的 是 函数 返回 行内 容 的 同时 去 除 HTML 标记 。 
【实例 8-9】 以 下 代码 演示 使 用 fgetss0 函 数 读 取 文件 中 的 内 容 。 


re 实例 8-9: 使 用 fgetss() 函 数 读 取 文件 中 的 内 容 
-| -源码 路 径 : 光盘 源 文 件 08\8-9php aa 


01 «html» 

02 <head> 

03 ”<title>fgetss() 函 数 使 用 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 // 打 开 文 件 的 同时 读 取 文件 指针 指向 的 行 

08 $myfile=fopen("data.txt","r"); /用 只 读 打开 文件 ， 文 件 指针 指向 文件 开头 
09 while(!feof($myfile)) 


t 
11 $myline-fgetss($myfile,255); /用 fgetss() 函 数 读 取 文 件 指针 所 在 行 并 值 赋 给 变量 
12 echo $myline; /显示 变量 


) 
14 fclose($myfile); /关闭 打开 的 文件 
15 ?> 
16 </body> 
17 «html» 


在 PHP 运行 环境 中 执行 以 上 代码 ， 会 出 现 如 图 8.3 所 示 的 执行 结果 。 
[Er 
|E ie/lecalhosvs- D ~ © | S 


| RAN 读 取 文件 内 容 读 取 文 件 内 容 | 


图 8.3 ”fgetss0 函 数 使 用 实例 执行 结果 
查看 源 文件 ， 只 有 以 下 内 容 : 


读 取 文 件 内 容 


KA aaa 


读 取 文件 内 容 
读 取 文件 内 容 


之 所 以 这 样 是 因为 data.txt 文件 只 有 第 3、 第 6 和 第 8 行 含有 文字 内 容 ， 其 他 行 均 为 HTML 标记 。 
在 使 用 fgetss(0) 函 数 去 除 标记 后 就 只 剩 第 3、 第 6 和 第 8 行 被 输出 了 。 


8.4.4 将 整个 文件 内 容 读 入 数组 变量 中 
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通常 把 一 个 多 行 的 文件 的 全 部 内 容 读 入 数组 变量 中 会 使 用 file(string filename) 函 数 。 参 数 filename 
为 一 个 字符 型 变量 ， 内 容 为 要 读 取 内 容 的 文件 名 。 该 函数 返回 一 个 数组 ， 数 组 长 度 为 文件 行 数 ， 文 件 
的 一 行 对 应 数组 的 一 个 元 素 。 
【实例 8-10】 以 下 代码 演示 使 用 file0) 函 数 读 取 整 个 文件 到 一 个 数组 中 。 
K < | 实例 8-10， 使 用 file() 函 数 读 取 整个 文件 到 一 个 数组 中 
| 源码 路 径 : 光盘 源 文件 088-l10php AA 


01 <html> 

02 <head> 

03 ”<title>file() 函 数 使 用 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 /使 用 file() 函 数 将 整个 文件 内 容 读 入 到 数组 变量 中 

08 S$filename="data.txt"; /定义 变量 
09 $myfile=file($filename); /用 file() 函 数 打开 文件 并 赋值 给 变量 
10 for($i=0; $i<count($myfile);$i++) INEF for 循环 

11 echo $myfile[Si]; /显示 数组 变量 的 每 个 元 素 

12 7> 

13 </body> 

14 </html> 


注意 : 如 果 被 读 入 的 文件 过 大 可 能 会 导致 程序 出 现 异 常 。 


在 PHP 运行 环境 中 执行 以 上 代码 ， 会 发 现 执行 结果 与 图 82 一 致 。 两 个 实例 都 是 通过 循环 显示 出 
了 文件 的 所 有 内 容 。 不 同 的 是 ，fgetc() 函 数 是 逐个 显示 各 个 字符 ， 而 file() 函 数 则 是 把 文件 读 入 数组 ， 
再 通过 显示 数组 元 素来 显示 出 文件 内 容 的 。 
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如 果 确 认 文件 已 经 没有 用 ， 并 且 以 后 也 不 会 再 用 到 ， 就 要 把 该 文件 删除 以 节省 硬盘 空间 。 在 PHP 


(m, 


中 使 用 unlink() 函 数 来 执行 这 一 操作 。 其 格式 如 下 : 
unlink(string filename) 


该 函数 中 参数 filename 是 字符 型 变量 ， 内 容 为 想 要 删除 的 文件 名 。 执 行 后 删除 指定 文件 。 如 果 出 
错 则 返回 0 或 者 False。 当 然 ， 使 用 这 一 函数 之 前 需要 确认 文件 确实 不 再 使 用 。 执 行 unlink() 函 数 后 文 
件 将 不 可 恢复 。 

【实例 8-11】 以 下 代码 演示 使 用 unlink() 函 数 删 除 指定 文件 。 


re 实例 8-11: 使 用 unlinkO) 函 数 删除 指定 文件 
源码 路 径 光盘 \ 源 文件 \08\8-11.php 


02 <head> 

03 ”<title>unlink() 函 数 使 用 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 /使 用 unlink() 函 数 删除 文件 

08 Sfilename-"data.txt"; /定义 变量 
09 unlink($filename); /用 unlink() 函 数 删除 文件 
(1052 

11 </body> 

12 </html> 


注意 : 使 用 unlink() 函 数 前 ， 一 定 要 确认 文件 已 经 不 再 需要 。 


在 PHP 运行 环境 中 执行 以 上 代码 后 进入 目录 会 发 现 data.txt 文件 已 经 被 删除 。 
使 用 此 函数 时 需要 注意 的 是 ， 删 除 的 文件 必须 是 存在 的 文件 ， 如 果 文 件 名 并 不 存在 ， 就 会 出 现 如 
图 8.4 所 示 的 出 错 提示 。 
| ES 
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Warning: unlink(data txt): No such file or directory in C: ApachelhtdocsiS-11 php on line 9 


I 


图 8.4 unlink(O) 函 数 使 用 不 当 的 出 错 提示 


8.6 创建 目录 
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有 时 需要 在 服务 器 上 创建 目录 。 如 创建 以 当天 日 期 为 名 字 的 目录 来 备份 数据 ， 或 者 创建 以 注册 用 
户 名 为 名 字 的 目录 来 存放 用 户 注册 信息 文件 等 。 在 PHP 中 使 用 mkdir(0) 函 数 来 完成 这 一 任务 。 

mkdir(string dimame,int mode) 


该 函数 中 参数 dirname 字符 变量 ， 表 示 想 要 创建 目录 的 名 称 ; 参数 mode 为 整 型 变量 ， 表 示 创 建 模 
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式 。 执 行 此 函数 将 在 指定 目录 下 创建 新 的 目录 。 
【实例 8-12】 以 下 代码 演示 使 用 mkdirO 函 数 创建 一 个 目录 。 


re 实例 8-12: 使 用 mkdir() 函 数 创建 一 个 目录 
源码 路 径 光盘 \ 源 文件 \08\8-12.php 


02 <head> 

03 ”<title>mkdir() 函 数 使 用 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 // 使 用 mkdir() 函 数 创建 目录 

08 $dirname-"mydir"; // 定 义 变量 
09 mkdir($dimame,0700); WA mkdir() 函 数 来 创建 目录 
10 ?> 

11 </body> 

12 </html> 


注意 : 在 Linux 系 统 中 需要 有 创建 目录 的 权限 。 
在 PHP 运行 环境 中 执行 以 上 代码 ， 进 入 目录 会 发 现 多 出 了 一 个 名 字 为 mydir 的 目录 。 需 要 注意 的 
是 ， 使 用 此 函数 时 ， 创 建 的 目录 名 不 能 与 已 经 存在 的 目录 名 相同 ， 如 果 出 现 了 同样 的 目录 名 ， 就 会 出 
现 如 图 8.5 所 示 的 出 错 提示 。 
| ET] 


OO 


m makdir() File exists in CAApachelhtdocsiS-12.php oa line 9 | 


| 


图 8.5 mkdir() 函 数 使 用 不 当 的 出 错 提示 
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同 普通 文件 类 似 的， 如 果 确认 目录 已 经 不 会 被 使 用 ， 那 么 就 要 把 目录 删除 。 在 PHP 中 使 用 rmdir() 
函数 来 执行 删除 目录 的 操作 。 

rmdir(string dimame) 


该 函数 中 参数 dirname 为 字符 型 变量 ， 表 示 想 要 删除 目录 的 名 称 。 执 行 此 函数 会 把 指定 目录 删除 。 
【实例 8-13】 以 下 代码 演示 使 用 rmdir() 函 数 删 除 指定 的 目录 。 


re 实例 8-13: 使 用 rmdir() 函 数 删除 指定 的 目录 
源码 路 径 : 光盘 \ 源 文件 \08\8-13.php 


01 <html> 
02 <head> 


第 8 章 PHPH 


03 ”<title>rmdir() 函 数 使 用 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 // 使 用 rmdir() 函 数 删 除 目 录 

08 $dirname-"mydir"; /定义 变量 

09 rmdir($dirname); /用 rmdir() 函 数 来 删除 目录 
(T0052 

11 </body> 

12 </html> 


在 PHP 运行 环境 中 执行 以 上 代码 ， 进 入 目录 会 发 现 名 为 mydir 的 目录 已 经 被 删除 。 在 使 用 这 个 函 
数 时 有 两 个 注意 事项 : 
回 ”目录 必须 为 室 ， 如 果 非 空 就 会 出 现 如 图 8.6 所 示 的 出 错 提示 。 
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Warning: rmdir(mydir). Directory not empty in C:\Apache\htdocs\$-13.php on line 9 


8.6 rmdir(0) 函 数 使 用 不 当 的 出 错 提示 1 
要 删除 的 目录 必须 存在 ， 如 果 删 除 不 存在 的 目录 ， 就 会 出 现 如 图 8.7 所 示 的 出 错 提示 。 


E 
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Warning: mdirimydir): No such file or directory in C:Apacheihtdocs\$-13.php on line 9 


图 8.7 rmdir0) 函 数 使 用 不 当 的 出 错 提示 2 
8.8 浏览 目录 下 的 文件 
YA 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 8 章 \ 浏 览 目录 下 的 文件 .wmv 


在 进行 PHP 编程 时 , 如 果 需 要 对 服务 器 某 个 目录 下 面 的 文件 进行 浏览 , 这 时 就 需要 用 到 opendir(). 
readdir() 或 者 closedir() 函 数 ， 如 表 8.3 所 示 。 


表 8.3 查看 目录 下 的 文件 相关 函数 


函 数 名 作 mH 
opendir(string path) | 打开 指定 目录 


参数 及 返回 值 
参数 path 为 目录 的 路 径 及 目录 名 , 函数 返回 值 为 可 供 其 他 目录 函数 使 用 的 
int 型 句柄 
参数 dir handle 为 已 经 用 opendir() 函 数 打 开 的 可 操作 目录 句柄 。 函 数 返回 
目录 中 的 文件 名 称 
参数 dir handle 为 已 经 用 opendir() 函 数 打开 的 可 操作 目录 句柄 。 函 数 无 返 
回 值 ， 运 行 后 ， 将 关闭 打开 指向 dir_ handle 的 目录 


readdir(int dir_handle) | 读 取 指定 目录 


closedir(int dir_ handle) | 关闭 指定 目录 


【实例 8-14】 以 下 代码 演示 使 用 表 8.3 中 所 示 的 函数 浏览 目录 下 的 文件 。 
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re 实例 8-14: 使 用 表 8.3 中 所 示 的 函数 浏览 目录 下 的 文件 
源码 路 径 : 光盘 \ 源 文件 \08\8-14.php 


03 <head> 

03 ”<title> 浏 览 目录 中 的 文件 实例 </title> 
04 </head> 

05 <body> 

06 <table border="1"> 

07 <tr> 

08 ”<td> 文 件 名 </td> 

09 ”<td> 文 件 大 小 </td> 

10 ”<td> 文 件 类 型 </td> 

11 ”<td> 修 改 时 间 </td> 


12 «ltr 

13 <?php 

14 $dirname-"data"; /定义 变量 

15 $dir_handle=opendir($dimame); /用 opendir() 函 数 打 开 目 录 
16 while($file=readdir($dir_handle)) // 循 环 读 取 目录 里 的 内 容 
17 { 

18 echo "<tr>"; 

19 echo "<td>".$file."</td>"; /显示 文件 名 

20 echo "<td>".filesize($file)."</td>"; /显示 文件 大 小 

21 echo "<td>" filetype($file)."«/td»"; /显示 文件 类 型 

22 echo "«td»" date("Y 4 n A t B" filemtime(Sfile))."«/td»"; /格式 化 显示 文件 修改 时 间 
23 echo "</tr>"; 

24 ) 

25 closedir($dir handle) /关闭 文件 操作 句柄 

26 ?> 

27 </table> 

28 </body> 

29 </html> 


注意 : 在 使 用 该 实例 代码 前 请 确保 同一 目录 下 有 data 文 件 夹 。 
在 PHP 运行 环境 下 执行 程序 ， 执 行 结果 如 图 8.8 所 示 。 


lee 
@ S hspi/ocahosys. O ~ È | B sername 

区 件 名 AE c ERE ET BT 

Boos — [dr Bol3 年 月 316 

Boss [dir po1385H31H 
mE fle Ro13 年 5 月 31 日 
1 contimue day3lprg s0 — tie poire Riso 
1 continue day3l overpng[I259 — |Fle D01259H30H 
1 continue overpng 1549 [fle [01259 H30H 
Per [fle [201345318 
2 unlock png 63 fle [|2012 年 9 月 30 晶 
D unlock over pug [1132 [fle 年 9 月 30 日 
Bt [Ele D0135:5H31H 
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当然 ， 显 示 细 节 会 因为 文件 夹 里 内 容 的 不 同 而 有 所 不 同 。 通 过 以 上 实例 可 见 ， 在 PHP 中 浏览 文件 
夹 中 的 内 容 也 并 不 是 一 件 多 么 复杂 的 事情 。 


8.9， 关 于 文件 上 传 
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文件 的 上 传 也 是 Web 应 用 程序 文件 操作 中 一 个 很 重要 的 组 成 部 分 。 因 为 大 部 分 文件 存在 于 用 户 客 
户 端的 机 器 上 ， 如 果 想 让 其 他 用 户 访问 则 必须 把 它 上 传 到 服务 器 。 如 图 片 网 站 上 传 图 片 、 软 件 下 载 站 
点 需要 上 传 软件 、 音 乐 站 点 需要 上 传 音乐 文件 等 。PHP 也 提供 了 对 文件 上 传 的 支持 ， 本 节 就 为 读者 介 
绍 PHP 中 关于 文件 上 传 的 操作 。 

PHP 是 通过 Web 表单 中 的 file 组 件 来 实现 文件 上 传 的 。 关 于 与 浏览 用 户 的 互动 的 Web 表单 将 在 第 
15 章 详 细 介绍 ， 本 节 只 是 拿 其 中 的 FILE 表单 来 实现 文件 上 传 的 目的 。 

PHP 的 文件 上 传 主要 是 利用 form. 表单 提交 一 个 file 对 象 给 服务 器 。 其 中 file 对 象 必 须 包含 
Multipar/form-data 的 entype 属性 。 同 时 考虑 到 大 文件 上 传 容易 造成 网 络 超时 的 情况 ， 所 以 可 以 用 
set_time_limit($TimeLimit) 函 数 来 加 大 超时 限制 时 间 。 

表单 提交 后 ，PHP 将 检测 上 传 的 文件 。 文 件 存放 在 服务 器 上 的 一 个 临时 目录 中 。 同 时 生成 几 个 与 
文件 域 (上 传 的 文件 ) 同名 的 变量 ， 如 _name 代表 文件 名 称 、_size 代表 文件 大 小 的 字 节 数 、_type 为 文 
件 的 类 型 。 由 于 临时 目录 会 被 删除 , 所 以 必须 利用 move uploaded file 0) 函数 将 文件 复制 到 目标 路 径 下 。 

【实例 8-15】 以 下 为 文件 上 传 的 前 台 代码 (因为 前 台 只 有 form 表单 ， 并 不 涉及 PHP 操作 ， 所 以 
里 面 内 容 并 没有 PHP 代码 ) 。 


re 实例 8-15: 文件 上 传 的 前 台 代码 
源码 路 径 ， 光盘 '\ 源 文件 ,08\8-15.php 


02 <head> 

03 ”<title> 文 件 上 传 的 前 台 页 面 实 例 </title> 
04 </head> 

05 <body> 

06 «form ENCTYPE-"multipart/form-data" ACTION="8-16.php" METHOD="POST"> 
07 <inputname="upfile" type="file"> 

08 <p> 

09 <input type=submit value=" 确 认 提交 "> 
10 <input type=reset value=" 重 新 选择 "> 
11 </body> 

12 </html> 


先 来 解释 一 下 , 以 上 代码 中 的 form 表单 有 一 个 属性 是 action="8-16.php"。 因为 这 里 要 使 用 8-16.php 
这 个 后 台 来 处 理 表单 的 提交 ， 所 以 要 把 form 表单 的 action 属性 指向 该 文件 。 
【实例 8-16】 以 下 代码 演示 文件 上 传 的 后 台 处 理 程序 。 


区 a 实例 8-16， 文 件 上 传 的 后 台 处 理 程序 
源码 路 径 : 光盘 \ 源 文件 \08\8-16.php 
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01 <html> 
02 <head> 
03 ”<title> 文 件 上 传 后 台 处 理 页 面 实例 </title> 
04 </head> 
05 <body> 
06 <?php 
07 if($ FILES[upfile]|name']-2NULL) 
08 { 
09 echo "没有 选择 文件 "; 
10 echo "<p>"; 
11 echo "点 <a href=\"8-15.php\"> 这 里 </a> 返 回 "; 
12 } 
13 else 
14 { 
15 $filepath="C:/Apache/htdocs/images/"; 
16 $tmp name-$ FILES[upfile']tmp nameT; 
17 Sfilename-$filepath.$ FILES[upfile][name'; 
18 echo $ FILES[upfile']name']; 
19 echo "<p>"; 
20 echo $ FILES[upfile"['size]; 
21 echo "<p>"; 
22 echo $ FILES[upfile']['type7]; 
23 if(move uploaded file($tmp name,$filename)) 
24 { 
25 echo "<p>"; 
26 echo "指定 文件 已 经 成 功 上 传 !"; 
27 echo "<p>"; 
28 echo "点 <a href=\"8-15.php\"> 这 里 </a> 返 回 "; 
29 } 
30 else 
31 echo "xc ffr E fit Wr"; 
32 ) 
33 ?> 
34 </body> 
35 </html> 
注意 : 上 传 文件 的 大 小 在 PHP 配 置 文件 中 有 限制 。 
先 在 PHP 运行 环境 中 执行 8-15.php 文件 ， 其 执行 


Sa 


结果 如 图 8.9 所 示 。 


// 没 有 选 定 文件 的 处 理 
// 显 示 提 示 信 息 

/给 出 返回 链接 

/ 选 定 文件 

/定义 路 径 


/新 的 路 径 及 文件 名 
// 显 示 文 件 名 


// 显 示 文 件 大 小 


/显示 文件 类 型 
/复制 文件 的 目标 路 径 


/给 出 返回 链接 


图 8.10. 不 选择 任何 文件 时 的 后 台 处 理 结 果 
单 击 图 8.10 中 的 “这 里 ”链接 ， 返 回 8-15.php。 这 次 选择 一 个 文件 ， 如 new.txt 文件 。 然 后 ， 单 击 
“确认 提交 ”按钮 (在 执行 这 一 步 之 前 ， 请 确认 8-15.php 的 同一 目录 下 有 images 目录 ) ，8-16.php 将 
会 返回 如 图 8.11 所 示 的 结果 。 


指定 文件 已 经 成 功 上 传 ! 
点 这 里 返 四 


图 8.11 ”正确 选择 文件 上 传 的 执行 结果 


从 图 8.11 的 结果 看 ， 是 正确 执行 了 文件 上 传 的 结果 。 打 开 8-16.php 同一 目录 下 的 images 文件 夹 ， 
发 现 里 面 多 了 一 个 名 为 new.txt 的 文件 ， 说 明 整 个 上 传 过 程 顺利 完成 。 


8.10 文件 操作 综合 实例 : 在 线 相 册 


本 节 将 综合 本 章 所 学 习 的 内 容 ， 来 建立 一 个 简单 的 基于 文件 及 文件 上 传 的 在 线 相册 系统 。 在 线 相 
册 拥 有 的 简单 功能 有 图 片 文件 上 传 、 图 片 浏 览 、 图 片 删除 等 。 本 节 把 本 章 所 学 的 知识 串联 起 来 ， 使 读 
者 进一步 熟悉 PHP 中 关于 文件 的 操作 。 


8.10.1 系统 功能 


C 知识 点 讲解 : BAWANE 8 章 \ 系 统 功能 .wmv 
整个 相册 管理 系统 要 实现 的 功能 有 图 片 文件 的 上 传 、 浏 览 、 删 除 操作 。 下 面 分 儿 小 节 来 创建 构成 
本 系统 的 几 个 重要 文件 。 这 里 先 列 出 代码 ， 然 后 再 对 每 一 个 文件 进行 解释 。 


8.10.2 ”相册 系统 首页 面 


GE 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 8 章 \ 相 册 系 统 首页 面 .wmv 

首先 来 编写 该 系统 的 第 一 个 显示 页 面 ， 它 将 读 取 存放 数据 的 文本 文件 的 内 容 ， 从 而 显示 出 相应 的 
图 片 。 并 且 ， 其 中 还 使 用 了 分 页 显示 ， 如 果 总 上 传 的 图 片 数 多 于 8 幅 ， 则 会 显示 下 一 页 的 链接 。 然 后 ， 
判断 所 在 的 页 ， 并 显示 出 相应 的 内 容 。 

【实例 8-17】 以 下 代码 为 相册 系统 的 首页 面 。 
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K | 实例 8-17， 相 册 系 统 的 首页 面 


源码 路 径 光盘 \ 源 文件 \08\8-17.php 


<html> 

<head> 

<title> 简 易 相册 系统 首页 </title> 
</head> 

<body> 

<center> 

<h1> 简 易 相 册 系 统 首页 </h1> 


«a href="8-18.php"> 上 传 图 片 </a><p> 


if(!$_GET["page"]) 
$page=1; 
else 
$page-$ GET['page"]; 
$filename-"data.dat"; 
$myfile-file(Sfilename); 
$z-Smyfile[0]; 
kuen) 
echo "目前 记录 条 数 为 : 0"; 
else 
{ 
$tempzexplode("||",Smyfile[0]); 
echo "共有 ".$temp[0]." 条 内 容 "; 
echo "&nbsp;&nbsp;&nbsp;&nbsp;"; 
$p. count-ceil($temp[0]/8); 
echo "分 ".$p_count." 页 显示 "; 
echo "&nbsp;&nbsp;&nbsp;&nbsp;"; 
echo "当前 显示 第 ".$page." 页 "; 
echo "<table border='1 >"; 
if($page!-ceil(Stemp[0]/8)) 
S$current size-8; 
else 
$current size-Stemp[0]?68; 
if(Scurrent size--0) $current size-8; 
for($i=0;$i<ceil($current_size/4);$i++) 
t 
echo "<tr>"; 
for($j=0;$j<4;$j++) 
{ 
echo "<td>"; 


// 如 果 没 有 参数 page 
// 则 显示 第 一 页 内 容 


// 如 果 带 有 参数 page， 则 显示 相应 页 内 容 
/指定 记录 数据 文件 名 

/使 用 file() 函 数 把 文件 所 有 信息 读 入 一 个 数组 
/把 数组 第 一 条 内 容 赋值 给 变量 

// 如 果 文 件 为 空 ， 即 没有 任何 图 片上 传 

// 显 示 没有 记录 的 信息 

// 如 果 有 图 片上 传 


// 读 出 数组 第 一 条 记录 到 数组 
// 读 出 该 数组 第 一 个 元 素 (代表 记 录 总 条 数 ) 


1/ 计算 总 页 数 为 记录 总 条 数 除 以 每 页 显示 条 数 
// 输 入 总 页 数 


[ETE 


// 如 果 当 前 页 不 是 最 后 一 页 

// 当 前 页 最 多 可 显示 8 条 记录 

// 如 果 当 前 页 是 最 后 一 页 

// 当 前 页 显示 的 条 数 为 总 条 数 除 以 8 的 余数 
// 如 果 正好 是 8 的 倍数 ， 则 显示 8 条 内 容 

// 通 过 循环 输出 行 ， 每 行 4 列 


// 通 过 循环 输出 单元 格 ， 共 4 个 


$temp=explode("||" $myfile[$i*4+$j+($page-1 )*8]);// 把 相应 的 记录 按 “|| ”分割 到 数组 


if((Si^4*Sj*(Spage-1)'8)«$z) 


{ 


Simgfile-"imagesW' .Stemp[1]; 
S$flag-getimagesize(Simgfile); 


// 如 果 当 前 数 小 于 总 数 显示 图 片 


/显示 图 片 为 数组 的 第 2 个 元 素 
/获得 图 片 的 大 小 以 供 处 理 


echo "<a href-8-20.php?id-".$temp[0]."»«img src=images\\".$temp[1]; 


if(Sflag[0]» 180||$flag[1]» 100) 


/如 果 图 片 太 大 


echo " width=180 height=".$flag[1]*180/$flag[0]; 
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49 echo " border=\"0\"></a>"; /把 图 片 按 比 例 缩放 显示 
50 n 

51 else // 和 如果 当前 数 比 总 记录 数 大 
52 echo "暂时 没有 图 片 "; /| 输出 没有 图 片 的 信息 
53 echo "</td>"; /| 结束 该 单元 格 

54 } 

55 echo "</tr>"; /| 结束 行 

56 ji 

57 echo "</table>"; /| 结束 表格 

58 H 

59 echo "<p>"; 

60 // 以 下 内 容 为 分 页 显示 链接 

61 $prev_page=$page-1; IA 

62 $next_page=$page+1; /下 一 页 

63 if ($5page«-1) /如 果 当 前 页 小 于 等 于 1 
64 echo "第 一 页 | "; 

65 else /如 果 当 前 页 大 于 1 

66 echo "<a href='$PATH_INFO?page=1'> 第 一 页 </a> |" 

67 if ($prev_page<1) /如果 前 一 页 小 于 1 

68 echo "上 一 页 | "; 

69 else // 如 果 前 一 页 大 于 等 于 1 
70 echo "<a href='$PATH_INFO?page=$prev_page'> 上 一 页 </a> |" 

71 if ($next_page>$p_count) /如 果 下 一 页 大 于 总 页 数 
72 echo "下 一 页 | "; 

73 else // 如 果 下 一 页 小 于 等 于 总 页 数 
74 echo "<a href='$PATH_INFO?page=$next_page'> 下 一 页 </a> |", 

75 if ($page»-$p count) // 如 果 当 前 页 大 于 等 于 总 页 数 
76 echo "最 后 一 页 </p>\n"; 

77 else // 如 果 当前 页 小 于 总 页 数 
78 echo "<a href='$PATH_INFO?page=$p_count'> 最 后 一 页 </a></p>\n"; 

te) reo 

80 </center> 

81 </body> 

82 </html> 


8.10.3 ”相册 系统 上 传 前 台 页 面 


GER 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 8 章 \ 相 册 系 统 上 传 前 台 页 面 .wmv 
接 下 来 制作 上 传 图 片 的 前 台 页 面 ， 这 个 页 面 中 没有 太 多 的 PHP 技术 ， 不 过 利用 了 JavaScript 技术 
来 实现 对 内 容 是 否 为 空 的 判断 。 
说 明 : 关于 JavaScript 的 内 容 ， 这 里 不 进行 介绍 ， 请 读者 参阅 相关 书籍 。 
【实例 8-18】 以 下 代码 为 相册 系统 上 传 前 台 页 面 。 
T | 实例 8-18: 相册 系统 上 传 前 台 页 面 
源码 路 径 : 光盘 \ 源 文件 \08\8-18.php 


01 «html» 
02 «head» 
03 <title> 相 册 管 理 系统 图 片上 传 页 面 </title> 


MULTI 


04 </head> 

05 <body> 

06 «script language-"javascript"» 

07 function Juge(theForm) 

08 { 

09 if (theForm.upfile.value == "") 

10 t 

11 alert(" 请 先 选择 文件 ! "); 

12 theForm.upfile.focus(); 

13 return (false); 

14 ) 

15 if (theForm.content.value == "") 

16 ( 

17 alert(" 请 输入 图 片 说 明 ! "); 

18 theForm.content.focus(); 

19 return (false); 

20 ) 

21 if (theForm.content.value.length»60) 

22 { 

23 alert(" 图 片 说 明 内 容 太 多 了 ， 请 删除 一 点 再 发 ! "); 
24 theForm.content.focus(); 

25 return (false); 

26 ) 

27 ) 

28 «script» 

29 «center» 

30 <h1> 相 册 管 理 系统 图 片上 传 页 面 </h1> 

31 <p> 

32 <a href="8-17.php"> 返 回首 页 </a> 

33 «table border-"1"» 

34 «form ENCTYPE-"multipart/form-data" ACTION-"8-19.php" METHOD-"POST" onsubmit 
= "return Juge(this)"»«tr» 

35 <td> 选 择 图 片 ，</td> 

36 <td> 

37 <input name="upfile" type="file"></td></tr> 
38 <tr> 

39 <td> 输 入 说 明 : </td> 

40 <td><input name-"content" type="text">(* 限 30 字 )</td></tr> 
41 <tr> 

42 <td colspan="2"> 

43 <center> 

44 <input type=submit value=" 确 认 提 交 "> 
45 «input type-reset value=" 重 新 选择 "> 
46 </center> 

47 </td></tr> 

48 </table> 

49 </center> 

50 </body> 

51 </html> 


其 中 的 form 表单 的 enctype 属性 必须 为 multipartform-data， 这 是 实现 文件 上 传 的 关键 。 另 外 ， 表 


(m, 
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单 的 action 属性 指向 8-19.php， 这 就 是 处 理 上 传 结果 的 页 面 ，8.10.4 小 节 就 来 创建 这 个 页 面 。 
8.10.4 相册 系统 上 传 后 台 页 面 


GÈ 知识 点 讲解 :光盘 \ 视 频 讲 解 \ 第 8 章 \ 相 册 系 统 上 传 后 台 页 面 .wmv 

该 页 面 实现 的 功能 不 仅 要 把 文件 上 传 到 目标 文件 夹 ， 而 且 还 要 把 相关 信息 写 入 记录 文件 之 中 。 所 
以 这 里 用 到 较 多 的 PHP 文件 操作 的 内 容 。 

【实例 8-19】 以 下 代码 为 相册 系统 上 传 后 台 页 面 。 


<head> 
<title> 相 册 管 理 系统 后 台 处 理 页 面 </title> 


</head> 
<body> 
<?php 


实例 8-19， 相 册 系 统 上 传 后 台 页 面 
源码 路 径 : 光盘 \ 源 文件 \08\8-19.php 


if($ FILES['upfile](name']--NULL)( 


) 


else( 


echo "没有 选择 文件 "; 
echo "<p>"; 
echo "点 <a href=\"8-18.php\"> 这 里 </a> 返 回 "; 


Sfilepath="C:/Apache/htdocs/images/"; 
$tmp name-$ FILES[upfile][tmp name]; 
Sfilename-$filepath.$ FILES[upfile']name']; 


if(move uploaded file($tmp name,Sfilename)) 


d 
$dataname="data.dat"; 
$myfile-file($dataname); 
if($myfile[0]--"") 
{ 


/如果 没有 选择 相应 的 文件 
// 输 出 信息 


// 给 出 返回 链接 


/定义 上 传 的 路 径 


/定义 文件 名 
// 如 果 文 件 被 顺利 复制 


/定义 记录 文件 名 
/使 用 file() 函 数 把 记录 文件 按 行 读 入 数组 
/如果 记录 文件 为 空 


$fp=fopen($dataname,"a+"); 
fwrite(Sfp,"1]|".Supfile name."||".$ POST['content"]."||'.date(Y ££ m A d H).^n"; 
fclose($fp); // 直 接 写 入 行 号 为 1 的 内 容 

} 

else // 如 果 记 录 文 件 非 空 即 已 经 有 内 容 

t 
S$temp-explode("||",Smyfile[0]); /把 第 一 条 记录 按 “||” 分 割 到 数组 
$temp[0]++; // 得 出 总 记录 数 并 自 增 1 
$fp=fopen($dataname,"r"); /以 只 读 方式 打开 文件 
$line_has=fread($fp,filesize("$dataname"));// 使 用 fread() 函 数 读 出 文件 已 经 存在 的 内 容 
fclose(Sfp); /关闭 文件 
$fp=fopen($dataname,"w"); /以 写 入 方式 打开 文件 
fwrite(Sfp.Stemp[0]."]|"-Supfile name."]||$ POST['content"]."|l'.date(Y ££ m A d H).n"; 

// 写 入 新 的 内 容 

fwrite($fp,"$line_has"); // 写 入 原来 已 经 存在 的 内 容 
fclose($fp); /关闭 文件 
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38 
39 
40 
41 
42 
43 


50 
51 


H 
echo "<p>"; 
echo "指定 文件 已 经 成 功 上 传 ! "s 
echo "<p>"; 
echo "点 <a href=\"8-17.php\"> 这 里 </a> 返 回 "; 
else 
echo "文件 上 传 失败 !"; 
y 

?> 

</body> 

</html> 


/给 出 返回 链接 


// 如 果 没有 复制 相应 文件 显示 失败 信息 


现在 文件 上 传 的 任务 完成 了 ，8.10.5 小 节 将 创建 显示 图 片 文件 全 部 信息 的 页 面 。 


8.10. 


5 相册 系统 浏览 图 片 详细 信息 页 面 


YA 知识 点 讲解 : 光盘 \ 视 频 讲 解 \ 第 8 章 \ 相 册 系 统 浏览 图 片 详细 信息 页 面 .wmv 
通过 前 两 小 节 的 页 面 ， 文 件 上 传 任务 已 经 完成 了 。 不 过 还 不 够 完善 ， 因 为 现在 系统 还 只 限于 能 上 


传 图 片 


。 如 何 浏览 图 片 文件 的 全 部 信 


息 呢 ? 本 小 节 来 创建 页 面 用 于 浏览 文件 的 详细 信息 。 其 实 就 是 利 


用 explode0) 函 数 ， 把 记录 内 容 分 割 到 数组 中 ， 再 分 别 显示 数组 各 个 元 素 而 已 。 


实例 8-20】 以 下 代码 为 浏览 图 片 详 细 信息 的 页 面 。 


TE 实例 8-20: 浏览 图 片 详细 信息 的 页 面 
b 源码 路 径 ， 光盘 \ 源 文件 \08\8-20.php 


142 


<head> 
<title> 简 易 相册 系统 查看 图 片 页 面 </title> 
</head> 
<body> 
<center> 
<h1> 简 易 相册 系统 查看 图 片 页 面 </h1> 
<p> 
«?ph 
ifl$ GET['id"]) 
t 


echo "没有 指定 ID"; 
echo "<p>"; 
echo "点 <a href=\"8-17.php\"> 这 里 </a> 返 回 "; 
exit(); 
} 
else 


{ 
?» 


// 和 如果 没有 指定 ID 
/输出 相应 信息 


/给 出 返回 链接 


/如 果 有 ID 


«a href="8-17.php"> 返 回首 页 </a>&nbsp;&nbsp;&nbsp;&nbsp; 


<a href="8-21.php?id=<? echo $id ?>"> 删 除 图 片 </a><p> 
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22 <? 

23 $id-$ GET['id"]; // 把 参数 赋值 给 变量 

24 $filename-"data.dat"; /定义 记录 文件 

25 $myfile=file($filename); /使 用 file() 函 数 把 文件 按 行 读 入 数组 
26 $z-Smyfile[0]; // 把 数组 第 1 个 变量 赋值 为 变量 
27 if(Sz--"") /如 果 记 录 数 为 0 

28 echo "目前 记录 条 数 为 : 0"; // 显 示 相 应 内 容 

29 else // 如 果 有 内 容 

30 { 

31 S$temp=explode("||",$myfile[$z-$id]); JA explode() 函 数 按 “|| ”把 相应 记录 分 割 
32 echo "<table border="1'>"; 

33 echo "<tr>"; 

34 echo "«td»"; 

35 echo "X: fF: ".Stemp[1]; /是 示 数组 第 二 个 元 素 即 文件 名 
36 echo "</td>"; 

37 echo "</tr>"; 

38 echo "<tr>"; 

39 echo "«td»"; 

40 echo "<img src=images\\".$temp[1].">"; /显示 图 片 

41 echo "</td>"; 

42 echo "</tr>"; 

43 echo "<tr>"; 

44 echo "<td>"; 

45 echo "图 片 简介 : ".Stemp[2]; // 显 示 图 片 第 三 个 元 素 即 图 片 简介 
46 echo "</td>"; 

47 echo "</tr>"; 

48 echo "<tr>"; 

49 echo "<td>"; 

50 echo "上 传 日 期 : ".Stemp[3]; /显示 图 片 第 四 个 元 素 即 上 传 日 期 
51 echo "</td>"; 

52 echo "</tr>"; 

53 echo "</table>"; 

54 } 

55 } 

56 ?> 

57 </center> 

58 </body> 

59 </html> 


一 般 情况 下 ， 有 了 上 述 几 个 文件 ， 已 经 可 以 满足 基本 的 需要 了 。 但 是 ， 如 果 想 要 把 没有 价值 的 图 


片 从 服务 器 上 删除 该 怎么 办 呢 ? 所 以 还 需要 一 个 页 面 用 于 实现 图 片 删除 的 操作 。8.10.6 小 节 就 来 创建 实 
现 图 片 删除 操作 的 页 面 。 


8.10.6 ”相册 系统 图 片 删除 页 面 


YA 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 8 章 \ 相 册 系 统 图 片 删除 页 面 .wmv 
要 删除 文件 其 实 很 简单 ， 使 用 unlinkO 函 数 就 可 以 了 。 可 现在 问题 是 不 光 要 把 文件 删除 ， 而 且 还 要 
对 记录 文件 作 相应 的 修改 。 删 除 文件 前 的 内 容 保持 不 变 , 删除 后 的 每 条 记录 还 得 减 1。 下 面 给 出 能 实现 


该 功能 的 文件 。 
【实例 8-21】 以 下 代码 为 图 片 删除 页 面 。 


<head> 
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实例 8-21: 图 片 删除 页 面 
源码 路 径 : 光盘 \ 源 文件 \08\8-21.php 


<title> 相 册 管 理 系统 删除 图 片 处 理 页面 </title> 


</head> 
<body> 
<?php 


error reporting(0); 
ifi$ GET['id"]) 


i 


echo "没有 指定 ID"; 
echo "<p>"; 


echo "点 <a href=\"8-17.php\"> 这 里 </a> 返 回 "; 


exit(); 


$id=$_GETI["id"]; 

S$filename-"data.dat"; 

$myfile-file(Sfilename); 

$z-$myfile[0]; 

if(Sz-- NULL) 
echo "目前 记录 条 数 为 : 0"; 

else 

{ 
S$temp=explode("||",$myfile[$z-$id]); 
$filepath-"images/"; 
S$imgfile-$filepath.Stemp[1]; 
unlink(Simgfile); 
for($i=0;$i<($z-$id);$i++) 


S$temp2=explode("||",$myfile[$i]); 
S$temp2[0]--; 
if($temp2[0]>0) 


// 如 果 没 有 指定 ID 
// 显 示 相 应 信息 
// 给 出 返回 链接 


/如 果 有 ID 


/把 参数 ID 赋值 给 变量 

/定义 记录 文件 

/使 用 file() 函 数 把 文件 按 行 读 入 到 数组 
/数组 第 一 个 元 素 赋值 给 变量 
/如果 第 一 行为 空 

/输出 没有 记录 

/如果 记录 非 空 


/使 用 explode() 函 数 分 割 相应 记录 到 数组 
/定义 路 径 

/获得 文件 名 

/删除 文件 

/从 第 一 条 记录 读 到 欲 删除 的 记录 


IH Fl explode() 函 数 分 割 相应 记录 到 数组 
// 记 录 号 实现 自 减 
// 判 断 是 否 为 最 后 一 条 记录 


S$text2-$text2.Stemp2[0]."]|" .Stemp2[1]."||".$temp2[2]."||".Stemp2[3]; 


5 
for($i=($z-$id+1);$i<$z;$i++) 
$text1=$text1.$myfile[$i]; 


} 
$fp=fopen($filename,"w"); 
fwrite($fp,$text2); 
fwrite($fp,$text1); 
fclose($fp); 


// 把 新 的 内 容 赋值 到 变量 


/将 欲 删 除 记 录 的 后 一 条 记录 作为 最 后 一 条 记录 


// 内 容 保持 不 变 


/以 写 入 方式 打开 文件 〈 文 件 同时 被 清空 ) 
// 写 入 欲 删 除 记录 之 前 自 减 后 的 所 有 记录 
// 写 入 欲 删 除 记录 后 的 所 有 记录 

/关闭 文件 


45 echo "指定 文件 已 经 删除 成 功 ! "s 
46 echo "<p>"; 
47 echo "点 <a href=\"8-17.php\"> 这 里 </a> 返 回 "; 


51 </body> 

52 </html> 

到 这 里 ， 整 个 相册 管理 系统 就 基本 上 完成 了 。 既 能 实现 文件 上 传 、 浏 览 ， 又 可 以 实现 对 图 片 文件 
的 删除 操作 。 下 面 ， 来 看 一 看 该 系统 的 执行 结果 ， 更 直观 地 感受 一 下 编程 带 来 的 乐趣 。 


8.10.7 测试 相册 系统 


GH 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 8 章 \ 测 试 相册 系统 ,wmv 
在 运行 此 系统 之 前 要 做 一 些 简单 的 准备 工作 。 第 一 ， 在 系统 同一 目录 下 建立 一 个 名 为 images 的 文 
件 夹 ; 第 二 ,在 系统 同一 目录 下 建立 一 个 名 为 data.dat 的 文本 文件 。 读 者 可 以 先 建 一 个 文本 文件 ， 里 面 
什么 也 不 要 输入 ， 然 后 把 扩展 名 改 为 dat 即 可 。 
准备 就 绪 ， 第 一 步 ， 先 运行 实例 8-17 中 的 代码 。 第 一 次 运行 ， 执 行 结果 如 图 8.12 所 示 。 
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上 估 图 片 


目前 记录 条 数 为 ，0 
第 一 页 | 上 一 页 | 下 一 页 | 最 后 一 不 


图 8.12 相册 系统 首页 第 一 次 运行 执行 结果 


由 于 此 时 还 没有 任何 图 片 被 上 传 ， 记 录 文 件 里 的 记录 是 空 的 。 单 击 “ 上 传 图 片 ”链接 ， 进 行 图片 
的 上 传 。 单 击 链接 后 ， 出 现 如 图 8.13 所 示 的 执行 结果 。 
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相册 管理 系统 图 片上 传 页 面 


返回 首页 
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图 8.13 ”相册 系统 图 片上 传 页 面 执行 结果 
单 击 “浏览 ”按钮 ， 选 择 相应 的 图 片 。 输 入 相应 的 图 片 说 明 ， 此 处 输入 “用 户 图 像 第 1 幅 图 ”。 再 单 
击 “ 确 认 提交 ”按钮 ， 就 把 图 片上 传 到 服务 器 上 了 。 由 于 8-19.php 的 输出 结果 很 简单 ， 只 是 简单 地 提示 上 
传 成 功 ， 然 后 给 出 一 个 返回 首页 的 链接 。 上 传 了 一 幅 图 片 的 8-17.php 的 效果 如 图 8.14 所 示 。 
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Rw% ~ 
图 8.14 上 传 了 一 幅 图 片 后 的 相册 系统 首页 执行 结果 


打开 目录 下 的 images 文件 夹 , 查看 里 面 也 增加 了 一 个 图 片 文 件 。 再 查看 相册 系统 目录 下 的 data.dat 
文件 ， 里 面 将 会 显示 如 下 信息 : 
1Il1.pngl| 用 户 图 像 第 1 幅 图 ||2013 年 05 月 06 日 


这 是 图 片 的 详细 信息 ， 包 插图 片 的 序号 、 文 件 名 、 图 片 说 明 、 上 传 日 期 等 。 说 明 记 录 文 件 正 确 记 
录 了 相关 内 容 。 此 时 可 以 直接 单 击 图 片 ， 以 查看 图 片 详细 信息 。 打 开 后 的 效果 如 图 8.15 所 示 。 
Wu | aaa 
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图 8.15 相册 系统 查看 图 片 详细 信息 页 


这 里 显示 出 了 已 经 上 传 图 片 的 详细 信息 。 单 击 “ 返 回首 页 ”链接 ， 以 继续 上 传 图 片 。 
现在 继续 上 传 图 片 ， 以 验证 系统 的 分 页 显示 功能 是 否 正常 运行 。 如 果 上 传 的 图 片 超过 了 8 幅 ， 实 
例 8-17 运行 界面 的 下 方 就 会 显示 出 到 另外 页 的 链接 ， 如 图 8.16 所 示 。 
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简易 相册 系统 首页 
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图 8.16 相册 系统 首页 的 分 页 功能 起 作用 了 


可 以 看 出 ， 最 上 面 显 示 的 内 容 是 “共有 9 条 内 容 分 2 页 显示 当前 显示 第 1 页 ”， 而 最 下 方 则 
显示 了 “下 一 页 ”及 “最 后 一 页 ”的 链接 。 这 里 单 击 “ 下 一 页 ”链接 ， 执 行 结果 如 图 8.17 所 示 。 
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图 8.17 相册 系统 首页 的 分 页 功能 测试 
这 里 显示 的 是 第 2 页 的 内 容 ， 说 明 分 页 功能 正常 。 这 时 再 单 击 “ 上 一 页 ”链接 ， 就 回 到 了 第 1 页 。 
这 时 ， 打 开 data.dat 文件 ， 里 面 将 会 有 以 下 内 容 : 


9||9.png|| FH P* RRE 9 幅 图 ||2013 年 05 月 06 日 
8||8.pngl| F. 第 8 幅 图 ||2013 年 05 A 06 A 
7Il7.pngll 用 户 图 像 第 7 幅 图 ||2013 年 05 月 06 日 
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记 下 这 些 内 容 ， 以 便 和 删除 图 片 的 内 容 作 比 较 。 接 下 来 ， 验 证 一 下 删除 用 户 上 传 图 片 功能 是 否 能 正 
HE 8.16 所 示 的 图 中 第 一 行 第 4 个 图 形 ， 将 出 现 查 看 图 片 详细 信息 的 页 面 ， 如 图 8.18 所 示 。 
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图 8.18 删除 图 片 前 的 准备 

由 于 系统 没有 设 定 对 删除 进行 确认 的 功能 ， 所 以 一 旦 单 击 了 “删除 图 片 ” 链 接 ， 对 应 的 图 片 就 会 

被 删除 。 这 时 要 记得 已 经 上 传 了 9 幅 图 片 ， 分 2 页 显示 。 单 击 “ 删 除 图 片 ”链接 ， 直 接 执行 了 8-21.php 
文件 。 执 行 完毕 会 提示 删除 成 功 ， 直 接 给 出 返回 首页 的 链接 。 回 到 首页 ， 结 果 如 图 8.19 所 示 。 
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849 ”删除 了 一 幅 图 片 后 的 结果 


内 容 又 成 了 8 条 ,并且 那 一 幅 图 片 6.gif 已 经 不 见 了 。 这 时 打开 data.dat 文件 ， 里 面 内 容 如 下 所 示 : 


8|l9.pngl| 用 户 图 像 第 9 幅 图 ||2013 年 05 月 06 日 
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与 前 面 的 data.dat 文件 内 容 相 比较 后 面 的 都 没 变 ， 前 面 的 序号 都 减少 了 1。 说 明正 常 完成 了 删除 图 
片 的 操作 。 

至 此 ， 本 系统 测试 完毕 。 通 过 对 这 个 图 片 管理 系统 的 调试 及 运行 ， 可 以 看 到 ， 里 面包 含 了 大 量 的 
文件 操作 的 内 容 及 技巧 ， 对 本 章 所 学 的 内 容 是 一 个 很 好 的 检阅 。 读 者 一 定 要 认真 领会 里 面 的 内 容 ， 学 
以 致 用 ， 把 学 到 的 内 容 用 到 实际 的 工作 中 去 。 

但 是 ， 这 个 系统 还 有 一 些 需要 完善 的 地 方 。 这 里 简要 介绍 一 下 ， 请 读者 自己 完成 。 

没有 对 用 户 上 传 内 容 作 判断 ， 用 户 可 能 会 上 传 不 是 图 片 的 文件 。 这 是 应 该 要 判断 的 。 解 决 办 
法 就 是 判断 文件 的 扩展 名 ， 或 者 使 用 getimagesize() 函 数 来 判断 图 片 类 型 ， 如 果 不 能 正确 返回 
值 ， 就 证 明 不 是 图 片 ， 不 予以 上 传 。 
没有 对 用 户 删 除 图 片 进 行 确认 。 如 果 用 户 误 单 击 了 链接 就 不 可 恢复 。 解 决 办 法 是 再 建 一 个 中 
间 页 面 ， 或 者 在 实例 8-21 的 代码 中 带 上 一 个 参数 ， 如 果 没 有 参数 则 只 是 给 出 警告 信息 ， 其 中 
有 指向 本 页 带 参数 的 链接 。 如 果 用 户 仍然 单 击 了 链接 ， 那 么 就 执行 删除 文件 操作 。 或 者 把 链 
接 做 如 下 简单 的 改动 ， 可 以 调用 JS 的 confirm 方法 来 达到 确认 的 目的 。 

以 下 是 未 改动 以 前 的 链接 : 

«a href="8-21.php?id=<? echo $id ?>"> 删 除 图 片 </a><p> 

改 为 如 下 样式 : 

«a onclick-"c()' href="8-21.php?id=<? echo $id ?>"> 删 除 图 片 </a> 

在 链接 中 加 入 了 一 个 onclick 事件 ， 然 后 再 在 实例 8-20 的 源 文件 中 加 入 以 下 JavaScript 代码 即 可 : 


<script language=javascript> 
function c() 
{ 


temp=confirm(" 确 定 要 删除 图 片 吗 ? "); 
if(temp--0) return else; 


回 


H 
</script> 


系统 存在 安全 隐患 ， 因 为 只 要 是 浏览 该 页 面 的 用 户 均 可 以 上 传 图 片 ， 同 时 也 能 删除 图 片 。 解 
决 办 法 是 判断 用 户 来 源 ， 或 者 直接 给 上 传 及 删除 页 面 加 上 密码 ， 只 有 密码 正确 才能 执行 相关 
操作 ， 这 样 就 提高 了 系统 的 安全 性 。 


8.11 AX x^ 


本 章 主要 介绍 了 PHP 编程 中 对 文件 的 操作 ， 包 括 判 断 文件 存在 、 获 取 文 件 属性 、 读 取 文件 内 容 、 
增删 目录 、 浏 览 目 录 等 文件 操作 ， 同 时 还 了 解 了 文件 上 传 的 操作 ， 学 习 了 PHP 文件 类 库 函 数 的 使 用 与 
技巧 。 因 为 文件 的 操作 在 PHP 编程 中 有 着 广泛 的 应 用 ， 所 以 熟练 掌握 这 些 函 数 的 使 用 及 文件 操作 的 技 
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对 PHP 的 Web 编程 将 起 到 事半功倍 的 效果 。 
812 本 章 习 题 


习题 8-1 使 用 file_exists0 函 数 判断 名 为 testfile.txt 的 文件 是 否 存在 ， 并 输出 相关 提示 信息 。 
【分 析 】 该 习题 主要 考查 读者 对 file_exists() 函 数 的 掌握 。 
【关键 代码 】 
if(file exists(testfile.txt')) 
echo ' 该 文件 存在 。"; 


else 
echo ' 该 文件 不 存在 '; 


习题 8-2 从 当前 目录 下 的 testfile.txt 文件 中 读 取 内 容 并 输出 。testfile.txt 文 件 的 内 容 如 下 : 
Happy New Year! 
【分 析 】 该 习题 主要 考查 读者 对 读 取 文件 的 掌握 情况 。 
【关键 代码 】 
Sfd-fopen(testfile.txt' 'r'); 
S$ch-fgets(Sfd); 
echo $ch; 
习题 8-3 ”使 用 在 当前 目录 下 创建 一 个 名 为 mydir 的 目录 并 在 成 功 后 输出 提示 信息 。 
【分 析 】 该 习题 考查 读者 对 mkdir0 函 数 的 掌握 。 
【关键 代码 】 
if(mkdir('mydir')) echo "创建 成 功 "; 
习题 8-4 ”使 用 readdir() 函 数 输 出 当前 目录 下 的 文件 。 
【分 析 】 该 习题 考查 读者 对 浏览 目录 下 文件 流程 的 掌握 。 
【关键 代码 】 


$dh=opendir('./'); 
while(Sfileszreaddir(Sdh))( 


echo $files; 
k 
closedir(Sdh); 
习题 8-5 ”使 用 move_uploaded_file() 函 数 将 从 名 为 file 的 form 表单 上 传 的 文件 保存 到 当前 目录 下 
F 保 持 上 传 时 的 名 称 。 


【分 析 】 本 习题 考查 读者 对 文件 上 传 的 掌握 。 
【关键 代码 】 
$tmp_name=$_FILES[file][tmp_name']; 


$file name=$_FILES[file]rname1]; 
move uploaded file(Stmp name,$file name); 


e. 


第 9 章 用 PHP 获取 主机 信息 


在 使 用 PHP 进行 网 络 编程 时 ， 让 用 户 了 解 主机 的 信息 及 使 用 者 的 情况 是 十 分 有 必要 的 。 如 主机 的 
操作 系统 类 型 、Apache 的 版 本 、PHP 解释 器 支持 的 函数 、 有 无 MySQL 数据 库 支 持 以 及 主机 的 日 期 、 
时 间 等 内 容 。 本 章 就 来 介绍 PHP 中 的 主机 函数 ， 内 容 包括 phpinfo0) 函 数 的 使 用 、 获 取 浏 览 器 相关 信息 
及 使 用 日 期 时 间 函 数 获 取 相 应 内 容 等 。 通 过 本 章 的 学 习 ， 读 者 对 于 获得 主机 信息 将 有 一 个 深层 次 的 
了 解 。 


9.1 phpinfo) £& 2 85 4f] 
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如 果 用 户 需 要 全 面 了 解 服务 器 的 相关 信息 ， 使 用 phpinfo0 函 数 是 最 为 方便 的 。 该 函数 没有 参数 ， 
直接 返回 主机 的 全 部 信息 ， 使 用 非常 方便 ， 返 回 内 容 相当 广泛 。 正 因为 该 函数 包括 了 太 多 的 内 容 ， 甚 
至 一 些 不 希望 被 用 户 发 现 的 内 容 ， 所 以 许多 服务 提供 商 往往 禁用 了 该 函数 。 
【实例 9-1】 以 下 代码 演示 如 何 使 用 phpinfo0 函 数 返 回 服务 器 信息 。 
D 实例 9-1: 使 用 phpinfo() 函 数 返回 服务 器 信息 
源码 路 径 : 光盘 \ 源 文件 \09\9-1.php - 


02 <head> 

03 ”<title>phpinfo() 函 数 使 用 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 phpinfo(); /显示 相关 信息 
08 ?> 

09 </body> 

10 </html> 


以 上 代码 相当 简单 ， 起 实质 作用 的 只 有 phpinfo0; 这 一 句 PHP 代码 。 在 PHP 运行 环境 中 执行 以 上 
代码 ， 其 执行 结果 如 图 9.1 所 示 。 


注意 : 以 上 信息 可 能 会 随 着 版 本 不 同 而 有 变化 。 
通过 图 9.1 可 见 ，phpinfo0 函 数 返 回 的 内 容 相当 多 ， 儿 乎 包括 了 所 有 与 PHP 主机 有 关 的 内 容 。 
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9.1. phpinfo() 函 数 使 用 实例 执行 结果 


9.2 ”获取 浏览 器 相关 信息 


在 使 用 PHP 编写 Web 应 用 程序 时 , 获取 用 户 浏览 器 相关 信息 也 是 十 分 必要 的 。 如 用 户 所 使 用 的 浏 
览 器 信息 、 操 作 系 统 的 类 型 、 客 户 机 的 IP 地 址 等 。 本 节 就 来 介绍 PHP 中 的 浏览 器 相关 操作 的 内 容 。 


9.2.1 获取 访问 者 浏览 器 信息 


(UE 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 9 章 \ 获 取 访 问 者 浏览 器 信息 .wmv 

流行 的 浏览 器 有 很 多 种 ， 如 微软 公司 的 IE. Google 公司 的 Chrome. Opera 以 及 火狐 (Firefox ) 等 。 
不 同 的 浏览 器 支持 的 标准 不 同 ， 对 相同 的 HTML 也 有 不 同 的 解释 。 所 以 根据 浏览 器 的 类 型 为 用 户 提 供 
相应 的 网 页 是 很 有 必要 的 。 在 PHP 中 判断 浏览 器 的 类 型 也 是 一 件 很 简单 的 事情 ， 简 单 到 只 使 用 系统 的 
内 置 系统 变量 $_ SERVER["HTTP_USER_AGENT"] 即 可 。 

在 第 3 章 介 绍 到 的 系统 变量 中 曾经 提 到 过 $_ SERVER 是 一 个 特殊 的 PHP 保留 变量 ， 它 包含 了 主机 
提供 的 所 有 信息 ， 被 称 为 自动 全 局 变量 (或 超级 全 局 变量 ) 。 要 显示 该 变量 ， 只 需 简单 地 进行 如 下 操 
作 ， 如 : 

<?php 


echo $ SERVER['HTTP USER AGENT"]; 
?» 


说 明 : 该 脚本 的 输出 可 能 是 : Mozilla/4.0(compatible; MSIE 5.01; Windows NT5.0)。 
【实例 9-2】 以 下 代码 演示 在 PHP 中 如 何 判 断 用 户 浏览 器 类 型 。 


€ . | “实例 9-2: ft PHP 中 如 何 判断 用 户 浏览 器 类 型 
源码 路 径 : 光盘 \ 源 文件 \09\9-2.php 
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01 «html» 

02 <head> 

O3 ”<title> 判 断 浏览 器 类 型 使 用 实例 </title> 
04 </head> 

05 <body> 

06 <?php 

07 echo "您 的 浏览 器 类 型 为 :"; 

08 echo "<p>"; 

09 if(strstr($_SERVER["HTTP_USER_AGENT"], "MSIE")) // 使 用 系统 变量 判断 用 户 浏览 器 类 型 
10 echo"Internet Explorer"; 
(dE? 

12 </body> 

13 </html> 


在 PHP 运行 环境 中 执行 以 上 代码 ， 其 执行 结果 如 图 9.2 所 示 。 


| 全 的 浏览 器 类 型 为 ， 


Internet Explorer 


RNS ~ 


图 92 ”判断 浏览 器 类 型 使 用 实例 执行 结果 
9.2.2 ”获取 访问 者 的 IP 地 址 
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在 实际 应 用 中 ， 判 断 用 户 IP 也 是 很 有 必要 的 。 如 网 上 投票 程序 就 要 用 IP 地 址 来 判断 用 户 是 否 已 
经 投 过 票 ， 限制 IP 计数 器 用 IP 地 址 来 判断 当天 用 户 是 否 已 经 浏览 站 点 。 在 PHP 中 的 $_SERVER 系统 
变量 包含 了 主机 的 几乎 所 有 信息 ， 所 以 IP 地 址 自然 也 可 以 使 用 这 个 变量 获得 ， 其 获得 方法 是 使 用 
$ SERVER["REMOTE ADDR"]. 

【实例 9-3】 以 下 代码 演示 使 用 $_SERVER 系统 变量 来 获得 访问 者 的 IP 地 址 。 


02 <head> 

03 ”<title> 获 得 访问 者 IP 地 址 使 用 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 echo "您 的 IP 地 址 为 :"; 

08 echo "<p>"; 

09 echo $_SERVER["REMOTE_ADDR"]; // 使 用 系统 变量 输出 用 户 IP 
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在 PHP 运行 环境 中 执行 以 上 代码 ， 执 行 结果 如 图 9.3 所 示 。 


图 9.3 ”获得 访问 者 IP 地 址 使 用 实例 执行 结果 
从 图 中 可 以 发 现 正确 显示 了 本 机 的 IP 地 址 。 
注意 : 由 于 是 在 单机 上 进行 调试 程序 ， 所 以 返回 的 只 是 单机 的 IP 地 址 。 
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在 编程 中 了 解 系统 的 日 期 及 时 间 也 是 很 有 必要 的 。 如 在 制作 留言 簿 时 ， 需 要 记录 用 户 的 留言 日 期 
及 时 间 ; 论坛 中 新 用 户 的 注册 日 期 及 时 间 等 。 在 PHP. 中 要 获得 系统 的 日 期 及 时 间 是 很 容易 的 ， 本 节 就 
为 读者 分 别 作 介 绍 。 


9.3.1 检查 日 期 的 合法 性 
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用 户 的 输入 内 容 不 一 定 是 想 要 取得 的 内 容 。 如 让 用 户 输入 生日 ， 用 户 很 有 可 能 输入 “2 月 30 日 ” 
这 样 不 通用 的 日 期 ， 而 不 合法 的 日 期 入 库 ， 将 会 给 统计 及 以 后 的 操作 带 来 很 多 不 便 。 因 此 ， 判 断 用 户 
输入 的 日 期 是 否 合法 是 很 有 必要 的 。 

PHP 中 有 专门 用 来 检查 日 期 是 否 合法 的 checkdate() 函 数 。 如 果 日 期 合法 就 返回 True， 反 之 则 返回 
False。 


【实例 9-4】 以 下 代码 说 明 checkdate0 函 数 是 如 何 使 用 的 。 


02 «head» 

03 ”<title> 检 查 日 期 合法 性 函数 使 用 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 if(checkdate(12,30,2013)) // 如 果 检 查 日 期 合法 
08 echo "12,30,2013 是 正确 的 日 期 ! "; 

09 else // 如 果 检 查 日 期 不 合法 
10 echo "12,30,2013 不 是 正确 的 日 期 ! "; 

11 echo "«p»"; 

12 if(checkdate(2,30,2013)) // 如 果 检 查 日 期 合法 
13 echo "2,30,2013 是 正确 的 日 期 ! "; 


14 else 

15 echo "2,30,2013 不 是 正确 的 日 期 ! "; 
16 ?» 

17 </body> 

18 </html> 
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在 PHP 运行 环境 中 执行 以 上 代码 ， 执 行 结果 如 图 9.4 所 示 。 


图 9.4 检查 日 期 合法 性 函数 使 用 实例 执行 结果 


学 习 过 英文 的 读者 都 知道 西方 的 日 期 表示 习惯 是 “月 、 日 、 年 ”; 所 以 从 图 9.4 结果 来 看 ，2013 
年 12 月 30 日 是 一 个 正确 的 日 期 ， 而 2013 年 2 月 30 日 则 是 一 个 错误 的 日 期 。 


9.3.2 格式 化 输出 当前 日 其 
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本 小 节 来 介绍 在 PHP 中 如 何 获得 当前 日 期 。 在 PHP 中 使 用 date0 函 数 加 上 不 同 的 参数 可 以 获得 不 


同 的 日 期 时 间 信 息 。 具 体内 容 如 表 9.1 所 示 。 


表 9.1 date() 函 数 的 参数 意义 及 返回 值 


5 m 


ik [E 值 


d 返回 有 前 导 零 的 2 位 数字 ， 从 01 到 31 
D 返回 3 个 字母 从 Mon 到 Sun 
返回 没有 前 导 零 的 数字 ， 从 1 到 31 

1 (“L” 的 小 写字 母 ) 返回 完整 的 文本 格式 从 Sunday 到 Saturday 

表示 每 月 天 数 后 面 的 英文 后 级 ^ das dist, nd, rd 或 者 也 。 可 以 和 j 

w 返回 0 CEMR) 到 6 (星期 六 ) 的 数字 

z 返回 从 0 到 366 的 数字 
um 返回 完整 的 文本 格式 ， 例 如 ，January 或 者 March, 

p 次 而 月 从 人 January 到 December 

m 以 数字 形式 表示 的 月 份 返回 有 前 导 零 的 2 位 数字 ， 从 01 到 12 

M 以 字母 形式 表示 的 月 份 返回 三 个 字母 缩写 表示 的 月 份 ， 从 Jan 到 Dec 

n 以 数字 形式 表示 的 月 份 (与 m 不 同 | 返回 无 前 导 零 的 位 数字 ， 从 1 到 12 

t 表示 一 月 的 天 数 返回 给 定 月 份 所 应 有 的 天 数 ， 从 28 到 31 

L 表示 是 否 为 半年 如 果 是 间 年 返回 1， 否 则 返回 0 

Y 表示 年 份 返回 4 位 数字 完整 表示 的 年 份 ， 如 1999 或 2003 
表示 年 份 〈 与 立 不 返回 2 位 数字 表示 的 年 份 ， 如 99 或 03 

a 以 小 写字 母 表示 上 午 或 下 午 返回 值 为 am 或 pm 

A 以 大 写字 母 表 示 上 午 或 下 午 返回 值 为 AM 或 PM. 


” ”PHP 网 络 编程 技术 详解 


续 表 
5 "m m m d 
£ 表示 小 时 ，12 小 时 格式 返回 没有 前 导 零 的 表示 小 时 的 数字 ， 从 1 到 12 
G 表示 小 时 ，24 小 时 格式 返回 没有 前 导 零 的 表示 小 时 的 数字 ， 从 0 到 23 
h 表示 小 时 ，12 小 时 格式 (与 g 不 同 〉| 返回 有 前 导 零 的 表示 小 时 的 两 位 数字 ， 从 01 到 12 
H 表示 小 时 ，24 小 时 格式 (与 G 不 同 ) | 返回 有 前 导 零 的 表示 小 时 的 两 位 数字 ， 从 00 到 23 
i 表示 分 钟 返回 有 前 导 零 的 分 钟 数 ， 从 00 到 59 
$ 表示 秒 返回 有 前 导 零 的 秒 数 ， 从 00 到 59 
如 EST、MDT 等 。 在 Windows 下 为 完整 文本 格式 ， 
T 表示 本 机 所 在 的 时 区 如 “EasternStandardTime”。 中 文 版 会 显示 “中 
标准 时 间 ” 
【实例 9-5】 以 下 代码 演示 如 何 获 得 系统 主机 的 日 期 及 时 间 。 
实例 9-5. 获得 系统 主机 的 日 期 及 时 间 
--- 源码 路 径 : 光盘 源 文件 099-5php ——000000000000000 0000000000000 
01 
02 <head> 
O3 ”<title> 输 出 当前 日 期 函数 使 用 实例 </title> 
04 </head> 
05 <body> 
06 <?php 
07 echo "今天 的 日 期 是 : " 
08 echo "<p>"; 
09 echo date("Y s n A d A"); /格式 化 日 期 
10 echo "<p>"; 
11 echo "今天 是 星期 : "; 
12 echo date("w"); /输出 星期 
13 echo "<p>"; 
14 echo "现在 的 时 间 是 : "; 
15 echo "<p>"; 
16 echo date("aG 点 i 分 s $5"); 
17 ?5 
18 </body> 
19 </html> 
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在 PHP 运行 环境 中 执行 该 文件 ， 执 行 结果 如 图 


9.5 所 示 。 


图 9.5 


输出 当前 日 期 函数 使 用 实例 执行 结果 
从 以 上 介绍 date0 函 数 的 参数 及 图 9.5 所 示 的 执行 结果 可 见 ， 使 


] date0 函 数 可 以 返回 


主机 的 当前 


第 9 章 BPHPERIKNÉR — 


的 日 期 。 
技巧 : 可 以 根据 不 同 的 用 户 区 域 ， 选 择 不 同 的 时 间 格 式 。 


93.3 ”获得 时 间 及 日 期 信息 


GI 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 9 章 \ 获 得 时 间 及 日 期 信息 .wmv 

通过 9.3.2 小 节 对 date0) 函 数 的 介绍 ,可 以 得 知 在 PHP 中 获得 时 间 及 日 期 信息 是 一 件 很 容易 的 事情 ， 
做 法 就 是 执行 date0 函 数 再 加 上 不 同 的 参数 即 可 。 下 面 介绍 另 一 个 常用 的 获得 日 期 信息 getdate() 函 数 。 
它 的 使 用 格式 如 下 所 示 : 

array getdate([int timestamp]) 

该 函数 可 包含 参数 ， 参 数 为 一 个 表示 日 期 的 数字 ， 如 果 没 有 参数 则 返回 当前 日 期 的 信息 。 返 回 值 
为 一 个 数组 。 其 返回 的 数组 中 内 容 很 多 ， 返 回 数组 的 键 名 及 相应 值 的 情况 如 表 9.2 所 示 。 

表 9.2 getdate() 函 数 的 返回 值 数 组 的 键 名 单元 


键 名 说 M 返回 值 例子 
"seconds" 秒 的 数字 表示 0 到 59 
"minutes" 分 钟 的 数字 表示 0 到 59 
"hours" 小 时 的 数字 表示 0 到 23 
"mday" 月 份 中 第 几 天 的 数字 表示 1 到 31 
"wday" 星期 中 第 几 天 的 数字 表示 0 (表示 星期 天 ) 到 6 (表示 星期 六 ) 
"mon" 月 份 的 数字 表示 1 到 12 
"year" A 位 数字 表示 的 完整 年 份 例如 : 1999 或 2003 
"yday" -年 中 第 几 天 的 数字 表示 0 到 365 
"weekday" 星期 几 的 完整 文本 表示 Sunday 到 Saturda 
"month" 月 份 的 完整 文本 表示 January 到 December 
【实例 9-6】 以 下 代码 演示 如 何 使 用 getdate0 函 数 获得 时 间 及 日 期 信息 。 
区 实例 9-6: 使 用 getdate() 函 数 获得 时 间 及 日 期 信息 
| 源码 路 径 : 光盘 \ 源 文件 099-6phbp 
01 <html> 
02 <head> 
03 ”<title> 获 得 时 间 及 日 期 信息 函数 使 用 实例 </title> 
04 </head> 
05 <body> 
06 <?php 
07 S$today-getdate(); 
08 echo "当前 年 份 为 :"; 
09 echo $today["year"]; 
10 echo "<p>"; 
11 echo "当前 月 份 为 :"; 
12 echo $today["month"]; 
13 echo "«p»"; 


KA aaa 


14 echo "当前 日 期 为 :"; 
15 echo $today["mday"]; 
16 echo "<p>"; 


17 echo "今天 是 全 年 中 的 第 : "; 

18 echo $today["yday"]." X"; 

19 echo "<p>"; 

20 echo "今天 是 星期 : " 

21 echo $today["wday"]; 

PEL qe 

23 </body> 

24 «html» 

在 PHP 运行 环境 中 执行 该 文件 ， 执 行 结果 如 图 9.6 所 示 。 


: 2013 
当前 月 份 为 ，Mav 
当前 日 期 为 7 
今天 是 全 十 中 的 第 ，126 天 
今天 是 县 期 2 
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图 9.6 获得 时 间 及 日 期 信息 函数 使 用 实例 执行 结果 


除了 可 以 无 参数 调用 getdate() 函 数 之 外 ,也 可 以 在 getdate() 函 数 中 使 用 参数 ,参数 可 以 为 任意 合法 
的 表示 日 期 的 数字 ， 函 数 一 样 会 返回 这 一 日 期 的 信息 。 

平时 编程 过 程 中 经 常用 到 PHP 中 的 日 期 时 间 函 数 ， 熟 练 使 用 这 些 函 数 ， 可 以 为 编写 复杂 的 Web 
程序 打下 基础 。 
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无 论 是 通过 系统 内 置 变 量 获得 主机 信息 ， 还 是 通过 日 期 时 间 函 数 获得 日 期 时 间 信息 ， 都 是 编写 大 
型 Web 应 用 程序 中 不 可 或 缺 的 内 容 ， 在 大 型 应 用 程序 中 都 是 基础 。 通 过 本 章 的 学 习 ， 读 者 应 该 对 获取 
主机 相关 信息 和 日 期 时 间 信 息 有 一 个 深刻 的 认识 。 


9.5 AŽ JA 


习题 9-1 使 用 checkdate0 函 数 检 查 如 下 日 期 的 合法 性 。 
2013-6-31 
【分 析 】 该 习题 考查 读者 对 checkdate() 函 数 的 掌握 。 
【关键 代码 】 
echo ' 该 日 期 是 '.(checkdate(6,31,2013)?' 合 法 “不 合法 '). 的 '; 


e. 
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习题 9-2 使 用 date(0) 函 数 输出 当前 是 一 年 中 的 第 几 天 。 
【分 析 】 该 习题 考查 读者 对 格式 化 输出 日 期 的 掌握 。 
【关键 代码 】 

echo ' 当 前 是 一 年 中 的 第 .date(z").' 天 '; 


习题 9-3 ”使 用 getdate() 函 数 获取 当前 的 年 、 月 份 。 
【分 析 】 该 习题 考查 读者 对 getdate() 函 数 的 使 用 。 
【关键 代码 】 


$d-getdate(); 
echo ': 8j" Sd['year']. 88". $d[ mon]. B; 
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使 用 过 Internet 的 用 户 都 知道 ， 一 个 网 站 不 可 能 离开 图 片 。 各 种 形式 的 图 片 ， 会 给 死板 的 网 页 带 来 
很 多 的 生机 。PHP 是 嵌入 式 的 语言 ， 所 以 PHP 页 中 除了 PHP 代码 之 外 都 是 HTML 标记 ，PHP 文件 中 
自然 可 以 使 用 图 片 标记 。 但 PHP 又 不 仅仅 是 能 用 图 片 而 已 , 它 还 能 对 图 片 进 行 处 理 。 本 章 讲解 PHP 中 
的 图 像 处 理 ， 内 容 包 括 PHP 中 的 简单 图 像 函数 、GD 库 函 数 的 使 用 、 图 像 使 用 实战 、 使 用 GD 函数 创 
建 图 像 、 使 用 GD 库 函 数 绘制 几何 图 形 、 使 用 GD 库 函 数 在 图 片上 写字 以 及 两 个 综合 实例 : 使 用 GD 
库 函 数 创 建 直方 统计 图 和 使 用 GD 库 函 数 创建 图 像 的 缩 略 图 。 


10.1 B & x Xx 


PHP 中 有 几 个 内 置 的 简单 图 像 处 理 函数 ， 还 有 功能 丰富 的 GD 库 函 数 。 简 单 的 图 像 函 数 可 以 用 来 
读 取 图 像 文件 的 长 、 宽 和 图 像 的 格式 ， 而 GD 库 函数 功能 就 强大 得 多 ， 可 以 创建 图 像 、 已 有 图 像 的 缩 
略图 、 在 图 片 文件 上 写字 等 。 


10.1.1 访问 图 像 的 属性 


E Join gHM: 光盘 \ 视 频 讲解 \ 第 10 章 \ 访 问 图 像 的 属性 .wmv 
在 处 理 一 个 图 像 文 件 之 前 ， 了 解 图 像 的 大 小 是 很 有 必要 的 。PHP 中 有 这 样 一 个 函数 用 来 返回 图 像 
的 长 、 宽 及 格式 。 这 个 函数 是 getimagesize0， 它 的 使 用 格式 如 下 所 示 
array getimagesize(string filename [,array &imageinfo]); 
该 函数 的 参数 为 指向 图 像 文件 路 径 及 文件 名 的 字符 串 ， 函 数 返 回 一 个 数组 。 该 数组 有 4 个 元 素 ， 
第 1 个 为 图 像 文 件 的 长 ， 第 2 个 为 图 像 文件 的 宽 ， 第 3 个 为 图 像 元 素 的 类 型 。 该 函数 支持 多 种 类 型 的 
图 像 ， 其 值 类 型 如 表 10.1 所 示 。 
表 10.1 getimagesize() 函 数 图 像 类 型 值 及 内 容 
指 代 的 图 像 类 型 
GIF 图 像 
JPG/JPEG 图 像 
PNG 图 像 
SWF (Flash) 文件 
PSD (Photoshop) 文件 
BMP 图 像 
TIFF 
TIFF 


函数 返回 值 


o Ja |o |o |» |o | 
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函数 返回 值 指 代 的 图 像 类 型 

9 JPC 文件 

10 JP2 文件 

ji JPX 文件 

12 JB2 文件 

13 SWC 文件 

14 IFF 文件 

15 WBMP 文件 

16 XBM 文件 


说 明 : 这 些 标记 与 PHP 4.3.0 新 加 的 IMAGETYPE 常 量 对 应 。 


第 4 个 参数 为 文本 字符 串 ， 内 容 为 “height="yyy",width="xxx"”， 可 直接 用 于 IMG 标记 。 


实例 10-1: 使 用 getimagesize() 函 数 来 访问 图 像 的 属性 
源码 路 径 ， 光盘 \ 源 文件 \10\10-1.php - 


01 <html> 

02 <head> 

03 ”<title> 访 问 图 像 属性 函数 使 用 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 Simage-"1 jpg"; /定义 指向 图 像 文件 的 字符 变量 
08 echo "<img src-".$image."»"; /| 插入 图 像 

09 $temp-getimagesize($image); /使 用 函数 并 把 返回 值 赋值 给 数组 
10 echo "<p>"; 

11 echo "该 图 像 的 长 为 : "; 

12 echo $temp[O0]; // 调 用 图 像 的 长 

13 echo "«p»"; 

14 echo "该 图 像 的 宽 为 : "5 

15 echo $temp[1]; // 调 用 图 像 的 宽 

16 echo "<p>"; 

17 echo "该 图 像 的 格式 为 : "; 

18 switch ($temp[2]) /通过 判断 返回 图 像 的 格式 
19 { 

20 case 1: // 如 果 图 像 为 GIF 

21 echo "GIF 图 像 "; 

22 break; 

23 case 2: // 如 果 图 像 为 JPG 

24 echo "JPG/JPGE 图 像 "; 

25 break; 

26 case 3: RARA PNG 

27 echo "PNG 图 像 "; 

28 break; 

29 default: / 除 以 上 3 种 外 的 其 他 情况 


E Lud 


30 echo "未 知 图 像 格 式 "; 
31 break; 

32 ) 

33 ?> 

34 </body> 

35 «html» 


在 PHP 运行 环境 中 执行 该 文件 〈 注 意 在 执行 该 文件 以 前 ， 先 把 1.jpg WE 10-1.php 的 同一 个 目录 
下 ) ， 其 执行 结果 如 图 10.1 所 示 。 


[c] E) Srssteaeniniés P- anameza. -| Tes AU 


WIRES. 60 
该 困 像 的 宽 为 ，426 
该 图 像 的 格式 为 ，IPG/JPGFE 图 党 


Awe 7 
图 10.1. 访问 图 像 属 性 函数 使 用 实例 执行 结果 


通过 实例 发 现 ，getimagesize() 函 数 能 返回 图 像 的 长 与 宽 及 图 像 类 型 。 这 个 函数 对 于 网 页 中 图 像 的 
插入 是 十 分 有 用 的 。 


10.1.2 ”使 用 GD 库 函 数 


C 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 10 章 \ 使 用 GD 库 函 数 .wmv 

PHP 的 GD 库 函 数 是 专门 用 来 处 理 图 像 、 画 图 的 库 函 数 ， 本 小 节 为 读者 介绍 PHP 中 常见 GD ER 
数 的 使 用 。 在 使 用 GD 库 之 前 要 先 让 PHP 解释 器 能 加 载 GD 库 .方法 就 是 修改 php.ini 文件 , 打开 php.ini 
文件 找到 这 一 行 


;extension-php gd2.dll 
把 前 面 的 “;” 去 掉 ， 然 后 ， 保 存 php.ini 文件 即 可 。 这 样 在 启动 PHP 解释 器 时 就 会 加 载 GD 库 函 数 。 
在 前 而 几 章 中 已 经 向 读者 展示 过 GD 库 的 强大 功能 ， 如 实例 6-7 和 实例 7-4， 第 6 章 的 重点 是 


如 何 使 用 非 系统 库 函 数 ， 而 第 7 章 主要 是 讲解 三 角 函 数 ， 下 面 对 这 两 个 实例 作 详 细 的 说 明 。 
以 下 代码 为 回顾 实例 6-7 的 代码 : 


(CN 


第 10 章 PHP 中 的 图 像 处 理 


01 <?php 

02 header("Content-type:image/png"); 

03 S$im-imagecreatetruecolor(440, 100); 

04 $black-imagecolorallocate(S$im, 0,0,0); 

05 $white-imagecolorallocate($im, 255,255,255); 

06 $yellow-imagecolorallocate($im,255,255,0); 

07 $blue-imagecolorallocate($im,0,0,255); 

08 $red-imagecolorallocate($im,255,0,0); 

09 $zi-imagecolorallocate($im,255,0,255); 

10 S$font-"courbd.ttf"; 

11 imagefilledrectangle(Sim, 5, 5, 435, 95, $blue); 

12 imagestring($im,5,7,10,"l:send",$white); 

13 for($i=0;$i<5;$i++) 

14 

15 imagettftext($im,40,0,90--$i*50,57,$yellow,Sfont,"Z"); 
16 } 

rz imagestring($im,5,270,60,"to: YOU As a gift", S white); 
18 imagestring($im,5,305,80,date(Y').".".date('m').".".date('d'),Swhite); 
19 Imagepng($im); 

20 Imagedestroy($im); 

21 7> 


/输出 一 个 PNG 图 片 文件 
/初始 化 图 形 区 域 
/定义 黑色 

/定义 白色 

/定义 黄色 
/定义 蓝 色 

/定义 红色 

/定义 紫色 

/定义 字体 文件 

/用 蓝 色 画 一 个 矩形 
/用 自 色 写字 符 

// 用 循环 画 字符 


// 画 出 字符 用 黄色 及 字体 


/用 自 色 写字 符 
// 写 出 当前 日 期 
// 创 建 图 形 
IRAAK 


该 实例 使 用 了 GD 库 中 的 创建 图 像 、 画 矩形 、 在 图 像 上 写字 符 等 几 个 函数 。 执 行 结果 如 图 6.7 所 示 。 
下 面 再 来 回顾 一 下 实例 7-4 中 的 代码: 


01 <?php 

02 header("Content-type: image/png"); 

03 $im = imagecreate(400,400); 

04 $black = imagecolorallocate($im, 0,0,0); 

05 $white = imagecolorallocate($im, 255,255,255); 
06 $yellow = imagecolorallocate($im,255,255,0); 
07 $blue = imagecolorallocate(S$im,0,0,255); 

08 $red - imagecolorallocate($im,255,0,0); 

09 imagefilledrectangle($im, 5, 5, 395, 395, $yellow); 
10 for($i=1;$i<360;$i++) 

11 ( 

12 Stemp-150*sin(2*(pi(/180)*$i); 

13 $x-$temp*cos((pi()/180)*$i)*200; 

14 Sy-Stemp'sin((pi()/180)*$i)*200; 

15 imagesetpixel ($im,$x,Sy,Sred); 

16 $temp-150*cos(2*(pi()/180)*Si); 

17 $x-$temp*cos((pi()/180)*$i)*200; 

18 Sy-Stemp'sin((pi()180)*$i)*200; 

19 imagesetpixel ($im,$x,$y,$blue); 

20 } 

21 Imagepng($im); 

22 Imagedestroy($im); 

ONE 


1/ 输出 文件 头 为 PNG 图 片 
/使 用 GD 库 函 数 创建 区 域 
/使 用 GD 库 函 数 定义 黑色 
// 使 用 GD 库 函 数 定义 白色 
// 使 用 GD 库 函 数 定义 黄色 
/使 用 GD 库 函数 定义 蓝 色 
/使 用 GD 库 函 数 定义 红色 
/使 用 GD 库 函 数 画 和 矩形 
// 通 过 循环 画 点 


/通过 三 角 函 数 计算 值 

/通过 三 角 函 数 计算 点 的 横 坐 标 
// 通 过 三 角 函 数 计算 点 的 纵 坐 标 
// 通 过 GD FAREA 
/通过 三 角 函 数 计算 第 二 个 值 
/通过 三 角 函 数 计算 点 的 横 坐 标 
/通过 三 角 函 数 计算 点 的 纵 坐 标 
// 通 过 GD FAREA 


/| 输出 PNG 图 片 
/清空 图 片 


(0 PHP 网 络 编程 技术 详解 


该 实例 除了 使 用 创建 图 像 函数 之 外 还 使 


位 置 画 一 个 点 。 


了 GD 库 函 数 中 的 画 点 函数 。 该 函数 的 作用 是 在 固定 的 


下 面 附 上 GD 库 中 的 常用 函数 及 意义 如 表 10.2 所 示 。 


表 10.2 常见 GD 库 函数 意义 


GD 库 函 数 意 x 
gd info 取得 当前 安装 的 GD 库 的 信息 
getimagesize 取得 图 像 大 小 
image type to extension R8 Ee ant acta d 
image type to mime type 取得 getimagesize, exif read data 
exif thumbnail, exif imagetype 所 返回 的 图 像 类 型 的 MIME 类 型 
image2wbmp 以 WBMP 格式 将 图 像 输出 到 浏览 器 或 文件 
imagealphablending 设 定 图 像 的 混 色 模式 
imageantialias 是 否 使 用 抗 锯齿 Cantialias) 功能 
imagearc 画 椭圆 弧 
imagechar 水 平地 画 一 个 字符 
imagecharup 垂直 地 画 一 个 字符 
imagecolorallocate 为 一 幅 图 像 分 配 颜色 
imagecolorallocatealpha 为 一 幅 图 像 分 配 颜色 + alpha 
imagecolorat 取得 某 像素 的 颜色 索引 值 
imagecolorclosest 取得 与 指定 的 颜色 最 接近 的 颜色 的 索引 值 
imagecolorclosestalpha 取得 与 指定 的 颜色 加 透明 度 最 接近 的 颜色 
imagecolorclosesthwb 取得 与 给 定 颜色 最 接近 的 色 度 的 黑白 色 的 索引 
imagecolordeallocate 取消 图 像 颜 色 的 分 配 
imagecolorexact 取得 指定 颜色 的 索引 值 
imagecolorexactalpha 取得 指定 的 颜色 加 透明 度 的 索引 值 
imagecolormatch 使 一 个 图 像 中 调 色 板 版 本 的 颜色 与 真 彩色 版 本 更 能 匹配 
imagecolorresolve 取得 指定 颜色 的 索引 值 或 有 可 能 得 到 的 最 接近 的 替代 值 
imagecolorresolvealpha 取得 指定 颜色 + alpha 的 索引 值 或 有 可 能 得 到 的 最 接近 的 替代 值 
imagecolorset 给 指定 调 色 板 索 引 设 定 颜色 
imagecolorsforindex 取得 某 索引 的 颜色 
imagecolorstotal 取得 一 幅 图 像 的 调 色 板 中 颜色 的 数目 
imagecolortransparent 将 某 个 颜色 定义 为 透明 色 
imageconvolution 用 系数 div 和 offset 申请 一 个 3X3 的 卷 积 矩阵 
imagecopy 复制 图 像 的 一 部 分 
imagecopymerge 复制 并 合并 图 像 的 一 部 分 
imagecopymergegray 用 灰 度 复制 并 合并 图 像 的 一 部 分 
imagecopyresampled 重 采 样 复制 部 分 图 像 并 调整 大 小 
imagecopyresized 复制 部 分 图 像 并 调整 大 小 
imagecreate 新 建 一 个 基于 调 色 板 的 图 像 
imagecreatefromgd2 从 GD2 文件 或 URL 新 建 一 图 像 


imagecreatefromgd2part 


从 给 定 的 GD2 文件 或 URL 中 的 部 分 新 建 一 图 像 
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GD 库 函 数 mox 
imagecreatefromgd 从 GD 文件 或 URL 新 建 一 图 像 
imagecreatefromgif 从 GIF 文件 或 URL 新 建 一 图 像 
imagecreatefromjpeg 从 JPEG 文件 或 URL 新 建 一 图 像 
imagecreatefrompng 从 PNG 文件 或 URL 新 建 一 图 像 
imagecreatefromstring 从 字符 串 中 的 图 像 流 新 建 一 图 像 
imagecreatefromwbmp 从 WBMP 文件 或 URL 新 建 一 图 像 
imagecreatefromxbm 从 XBM 文件 或 URL 新 建 一 图 像 
imagecreatefromxpm 从 XPM 文件 或 URL 新 建 一 图 像 
imagecreatetruecolor 新 建 一 个 真 彩色 图 像 
imagedashedline 画 一 虚线 
imagedestroy 销毁 一 图 像 
imageellipse 画 一 个 椭圆 
imagefill 区 域 填充 
imagefilledarc 画 一 椭圆 弧 且 填充 
imagefilledellipse 画 一 椭圆 并 填充 
imagefilledpolygon 画 一 多 边 形 并 填充 
imagefilledrectangle 画 一 矩形 并 填充 
imagefilltoborder 区 域 填充 到 指定 颜色 的 边界 为 止 
imagefilter 对 图 像 使 用 过 滤器 
imagefontheight 取得 字体 高 度 
imagefontwidth 取得 字体 宽度 
imageftbbox 给 出 一 个 使 用 FreeType2 字体 的 文本 框 
imagefttext 使 用 FreeType2 字体 将 文本 写 入 图 像 
imagegammacorrect 对 GD 图 像 应 用 gamma 修正 
imagegd2 将 GD2 图 像 输出 到 浏览 器 或 文件 
imagegd 将 GD 图 像 输出 到 浏览 器 或 文件 
imagegif VÀ GIF 格式 将 图 像 输出 到 浏览 器 或 文件 
imageinterlace 激活 或 禁止 隔行 扫描 
imageistruecolor 检查 图 像 是 否 为 真 彩色 图 像 
imagejpeg 以 JPEG 格式 将 图 像 输出 到 浏览 器 或 文件 
imagelayereffect 设 定 alpha 混 色 标志 以 使 用 绑 定 的 libgd 分 层 效 果 
imageline 画 一 条 线段 
imageloadfont 载 入 一 新 字体 
imagepalettecopy 将 调 色 板 从 一 幅 图 像 复 制 到 另 一 幅 
imagepn 以 PNG 格式 将 图 像 输出 到 浏览 器 或 文件 
imagepolygon 画 一 个 多 边 形 
imagepsbbox 给 出 一 个 使 用 PostScript Typel 字体 的 文本 方 框 
imagepsencodefont 改变 字体 中 的 字符 编码 矢量 
imagepsextendfont 扩充 或 精简 字体 
imagepsfreefont 释放 一 个 PostScript Typel 字体 所 占用 的 内 存 
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imagepsloadfont 
imagepsslantfont 


从 文件 中 加 载 一 个 PostScriptT 


imagepstext 用 PostScript Typel 字体 把 文本 字符 串 画 在 图 像 上 
imagerectangle 画 一 个 矩形 

imagerotate 用 给 定 角度 旋转 图 像 

imagesavealpha 设置 标记 以 在 保存 PNG 图 像 时 保存 完整 的 alpha 通道 信息 与 单一 透明 色相 反 》 
imagesetbrush 设 定 画 线 用 的 画笔 图 像 

imagesetpixel 画 一 个 单一 像素 

imagesetstyle 设 定 画 线 的 风格 

imagesetthickness 设 定 画 线 的 宽度 

imagesettile 设 定 用 于 填充 的 贴图 

imagestring 水 平地 画 一 行 字符 串 

imagestringup 垂直 地 画 一 行 字符 串 

imagesx 取得 图 像 宽度 

images; 取得 图 像 高 度 

imagetruecolortopalette 将 真 彩色 图 像 转换 为 调 色 板 图 像 


imagettfbbox 
imagettftext 
imagetypes. 
imagewbmp 
imagexbm 
iptcembed 
iptcparse 
jpeg2wbmp 
png2wbmp 


取得 使 用 TrueType 字体 的 文本 的 范围 

用 TmeType 字 体 向 图 像 写 入 文本 

返回 当前 PHP 版 本 所 支持 的 图 像 类 型 

以 WBMP 格式 将 图 像 输 出 到 浏览 器 或 文件 

将 XBM 图 像 输 出 到 浏览 器 或 文件 

将 二 进 制 IPTC 数据 嵌入 到 一 幅 JPEG 图 像 中 
将 二 进 制 IPTC http://www.iptc.org/ 块 解析 为 单个 标记 
将 JPEG 图 像 文 件 转换 为 WBMP 图 像 文件 

将 PNG 图 像 文件 转换 为 WBMP 图 像 文 件 


从 表 102 可 以 看 出 ，PHP 的 GD 库 函数 功能 相当 丰富 ， 几 乎 涵盖 了 图 像 处 理 中 的 所 有 内 容 。 下 面 


画图 、 绘 制 几何 图 形 、 在 图 形 上 写字 等 ， 从 中 读者 能 够 学 习 到 常用 GD 库 函数 的 使 用 及 图 像 处 理 的 


技巧 。 


10.2.1 使 用 GD 库 函 数 创建 图 像 


EB 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 10 章 \ 使 用 GD 库 函数 创建 图 像 -wmv 
在 使 用 一 个 图 像 之 前 必须 要 先 创建 它 。 通 过 查看 表 10.2 中 的 GD 库 函数 可 以 发 现 ， 要 创建 一 个 图 


(m, 
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像 就 使 用 imagecreate() 函 数 ， 它 的 使 用 格式 如 下 所 示 : 
resource imagecreate(int x_size,int y size) 
S3 x size. y size 为 整 型 变量 ， 内 容 为 所 创建 图 像 的 宽 与 高 。 该 函数 返回 一 个 图 像 标识 符 ， 代 表 
了 一 幅 宽 与 高 为 size 和 y size 的 空白 图 像 。 
注意 : 由 于 要 向 浏览 器 输出 一 幅 图 像 ， 所 以 使 用 此 函数 之 前 要 使 用 header("Content-type: image/png");3f- 
且 在 使 用 header(0) 函 数 之 前 不 能 有 包括 空 字符 在 内 的 任何 输出 。 


【实例 10-2】 以 下 代码 演示 如 何 使 用 imagecreate() 函 数 创建 图 像 。 


re 实例 10-2: 使 用 imagecreate() 函 数 创建 
源码 路 径 ， 光盘 \ 源 文件 \10\10-2.php 


01 <?php 

02 header("Content-type:image/png"); /向 浏览 器 输出 文件 头 
03 $im=imagecreate(100,50); /使 用 函数 创建 图 像 
04 $background color = imagecolorallocate($im,255,255,255); /设置 背景 色 

05 $text color = imagecolorallocate($im,233,14,91); /定义 文本 内 容颜 色 
06 imagestring($im,1,5,5,"A Simple Text String", $text_color); IIS Xo 

07 imagepng($im); /| 输出 PNG 

08 imagedestroy($im); NASAR 

09 7» 


在 PHP 运行 环境 中 执行 以 上 代码 ， 其 执行 结果 如 图 10.2 所 示 。 
f isl 


| LINE 


图 10.2 imagecreate() 函 数 使 用 实例 执行 结果 


通过 该 实例 及 其 执行 结果 可 见 创建 一 个 图 像 的 过 程 。 先 创建 图 像 ， 再 在 图 像 上 进行 操作 。 本 实例 
实现 的 效果 是 先 创建 一 个 图 像 ， 再 把 文本 输出 到 已 经 存在 的 图 像 上 。 


10.22 创建 图 形 并 在 上 面 画 图 


G 知识 点 讲解 : 光盘 \ 视 频 讲 解 \ 第 10 章 \ 创 建 图 形 并 在 上 面 画图 .wmv 

102.1 小 节 介绍 了 如 何 创 建 图 形 , 图 形 创 建 后 就 是 如 何 操作 的 问题 了 。 本 小 节 讲解 如 何在 图 形 上 面 
画 出 几何 图 形 。GD 库 函 数 能 直接 在 图 像 上 绘制 直线 、 和 矩形 、 圆 形 、 椭 圆 形 等 几何 图 形 。 下 面 来 分 别 说 
明 这 几 个 函数 的 使 用 方法 。 

bool imageline) F Žít: 


bool imageline(resource image, int x1, int y1, int x2,int y2,int color) 


参数 image 为 一 个 已 经 创建 的 图 形 对 象 ， 参 数 x1、y1、x2、y2 均 为 整 型 数 ，color 为 表示 颜色 的 整 
型 数 。 执 行 函数 ， 将 会 用 color 颜色 画 一 条 从 xl1，yl 到 x2，y2 的 直线 。 


KA aaa 


yl; 


CX, 


bool imagerectangle() FR t : 

bool imagerectangle(resource image,int x1,int y1,int x2,int y2,int color) 

参数 内 容 与 imageline0) 函 数 相 似 。 执 行 函数 ， 将 会 用 color MEMA, ERE E4829 x1; 
右 下 角 坐 标 为 x2，y2。 

bool imagefilledrectangle()FR Xi : 

bool imagefilledrectangle(resource image,int x1,int y1,int x2,int y2,int color) 

执行 函数 将 会 画 一 个 矩形 ， 与 上 一 个 函数 不 同 的 ， 此 和 撼 形 是 一 个 用 color 填充 的 和 矩形。 

bool imageellipse() FK Zi: 

bool imageellipse(resource image,int cx,int cy,int w,int hint color) 

参数 cx、cy、w、h 均 为 整 型 数 。 执 行 函数 ， 将 会 画 一 个 颜色 为 color 的 椭圆 ， 该 椭圆 的 左上 角 为 
cy. w, h 为 椭圆 的 宽度 和 高 度 ， 如 果 两 者 相等 画 出 的 就 是 一 个 正 圆 形 。 

bool imagefilledellipseO) 函 数 : 

bool imagefilledellipse(resource image,int cx,int cy,int w,int hint color) 


基本 内 容 同 上 也 是 绘制 椭圆 ， 不 同 的 是 此 函数 画 出 的 椭圆 也 是 填充 的 实心 图 形 。 


01 <?php 

02 header("Content-type:image/png"); /向 浏览 器 输出 文件 头 
03 $im=imagecreate(500,500); /使 用 函数 创建 图 像 
04 $black=imagecolorallocate($im, 0,0,0); /定义 黑色 

05 $white=imagecolorallocate($im, 255,255,255); /定义 和 白色 

06 $yellow=imagecolorallocate($im,255,255,0); /定义 黄色 

07 $blue =imagecolorallocate($im,0,0,255); /定义 蓝 色 

08 S$red-imagecolorallocate($im,255,0,0); /定义 红色 

09 $zi=imagecolorallocate($im,255,0,255); /定义 紫色 

10 $background color = imagecolorallocate($im,255,255,255); Ing ERE 

11 imageline(S$im,10,10,350,10,$white); /用 自 色 画 直线 

12 imagerectangle($im,20,20,200,100,$blue); /用 蓝 色 画 一 个 矩形 
13 imagefilledrectangle($im,100,200,200,300,$yellow); /用 黄色 画 一 个 填充 矩形 
14 imageellipse($im,50,50,150,150,$zi); // 用 紫色 画 一 个 椭圆 
15 imagefilledellipse($im,50,50,150,350,$white); // 用 白色 画 一 个 正 圆 形 
16 imagepng($im); /| 输出 PNG 

17 imagedestroy($im); NASER 

18. 7> 


在 PHP 运行 环境 中 执行 该 文件 代码 ， 其 执行 结果 如 图 10.3 所 示 。 
通过 上 面 的 实例 及 执行 结果 ， 可 以 发 现 GD 库 函 数 可 以 绘制 几乎 所 有 的 几何 图 形 。 通 过 自己 的 创 


意 ， 能 绘 出 更 多 的 项 目 。 


e. 
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图 10.3 使 用 GD 函数 在 图 像 上 绘制 几何 图 形 
10.2.3 绘制 几何 图 形 更 多 的 探索 


知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 10 章 \ 绘 制 几何 图 形 更 多 的 探索 .wmv 

本 节 利 用 GD 库 中 的 画 直 线 函数 imageline() 来 做 更 多 的 探索 。 利 用 画 直线 函数 来 达到 夯 三 角形 、 
五 角 星 及 更 复杂 图 形 的 目的 。 

复杂 的 图 形 归根 结 底 都 是 由 简单 的 直线 或 者 曲线 构成 的 ， 只 要 掌握 了 构图 的 规律 ， 就 可 以 用 简单 
的 直线 来 描绘 出 复杂 的 图 形 。 

【实例 10-4】 以 下 代码 演示 使 用 直线 画 正三 角形 。 


区 实例 10-4: 使 用 直线 画 正三 角形 
源码 路 径 : 光盘 '\ 源 文件 10\10-4.php 


01 <?php 

02 header("Content-type:image/png"); /向 浏览 器 输出 文件 头 
03 S$imzimagecreate(400,300); // 使 用 函数 创建 图 像 
04 $background color = imagecolorallocate($im,0,0,0); // 设 置 背 景色 

05 $white=imagecolorallocate($im, 255,255,255); /定义 白色 

06 imageline($im,100,50,300,50,$ white); // 画 线 

07 imageline($im,100,50,200,50+200*sin(pi()/3),$white); // 画 线 

08 imageline($im,200,50+200*sin(pi()/3),300,50,$white); // 画 线 

09 imagepng($im); /输出 PNG 

10 imagedestroy($im); NASAR 

iU cem 


在 PHP 运行 环境 中 执行 以 上 代码 ， 其 执行 结果 如 图 10.4 所 示 。 
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图 10.4 用 画 直线 函数 绘制 正三 角形 
既然 能 用 画 直 线 函 数 画 出 正三 角形 ， 当 然 也 可 以 用 它 来 绘制 五 角 星 了 。 


实例 10-5: 使 用 画 直 线 函 数 绘制 五 角 星 
源码 路 径 ， 光 盘 \ 源 文件 \10\10-5.php 


01 <?php 
02 header("Content-type:image/png"); /向 浏览 器 输出 文件 头 
03 $im=imagecreate(400,400); /使 用 函数 创建 图 像 
04 $black=imagecolorallocate($im, 0,0,0); /定义 黑色 
05 $white=imagecolorallocate($im, 255,255,255); /定义 白色 
06 $red-imagecolorallocate($im,255,0,0); /定义 红色 
07 $background color = imagecolorallocate($im,255,255,255); // 设 置 背 景色 
08 imagefilledrectangle($im,5,5,395,395,S$white); NAABER 
09 $m=200; // 边 长 
10 $n-sqrt($m*$m*$m*$m-2*$m*$m*cos(3*pi()/5)); // 大 边 长 
11 $a=cos(2*pi()/5)*$n; // 设 置 变量 以 求 顶点 坐标 
12 $b=sin(2*pi()/5)*$n; 
13 $c=cos(pi()/5)*$m; 
14 $d=sin(pi()/5)*$m; 
15 imageline($im,200,50,200-$a,50*$b,$red); // 画 线 
16 imageline($im,200,50,200+$a,50+$b, $red); // 画 线 
17 imageline($im,200-$c,50+$d,200+$a,50+$b,$red); // 画 线 
18 imageline($im,200+$c,50+$d,200-$a,50+$b, $red); // 画 线 
19 imageline($im,200-$c,50+$d,200+$c,50+$d,$red); // 画 线 
20 imagepng($im); /输出 PNG 
21 imagedestroy($im); /销毁 图 像 
SEL Fe 
说 明 : 以 上 代码 的 重点 就 是 确定 各 个 顶点 的 坐标 。 
在 PHP 运行 环境 中 执行 以 上 代码 ， 执 行 结果 如 图 10.5 所 示 。 
对 于 此 五 角 星 来 说 ， 画 线 的 过 程 相当 简单 ， 主 要 是 利用 数学 原理 来 求 各 个 项 点 的 坐标 相对 麻烦 。 


下 面 使 用 画 直 线 函 数 imageline() 来 绘制 正 十 二 角 星 。 
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图 10.5 使 用 画 直 线 函 数 绘制 五 角 星 


01 <?php 

02 header("Content-type:image/png"); /向 浏览 器 输出 文件 头 
03 $im=imagecreate(420,420); /使 用 函数 创建 图 像 
04 $black=imagecolorallocate($im, 0,0,0); /定义 黑色 

05 $white=imagecolorallocate($im, 255,255,255); /定义 和 白色 

06 $blue-imagecolorallocate($im,0,0,255); /定义 蓝 色 

07 $background color = imagecolorallocate($im,255,255,255); /设置 背 景色 

08 imagefilledrectangle($im,5,5,415,415,Swhite); /用 自 色 画 一 个 矩形 
09 imageline($im,210,10,110,210+100*sqrt(3),$blue); / 画 线 

10 imageline($im,210,10,310,210+100*sqrt(3),$blue); // 画 线 

11 imageline($im,210,410,110,210-100*sqrt(3),$blue); // 画 线 

12 imageline($im,210,410,310,210-100*sqrt(3),$blue); // 画 线 

13 imageline(Sim,10,210,210--100*sqrt(3),110,$blue); // 画 线 

14 imageline($im,10,210,210+100*sqrt(3),310,$blue); // 画 线 

15 imageline($im,410,210,210-100*sqrt(3),110,$blue); // 画 线 

16 imageline($im,410,210,210-100*sqrt(3),310,$blue); // 画 线 

17 imageline($im,110,210-100*sqrt(3),210+100*sqrt(3),310,$blue); / 画 线 

18 imageline($im,110,210+100*sqrt(3),210+100*sqrt(3),110,$blue); // 画 线 

19 imageline($im,210-100*sqrt(3),110,310,210100*sqrt(3),$blue); ”// 画 线 

20 imageline($im,210-100*sqrt(3),310,310,210-100*sqrt(3),$blue); ”// 画 线 

21 imagepng($im); /| 输出 PNG 

22 imagedestroy (Sim); IESER 

2999 


在 PHP 运行 环境 下 执行 该 PHP 文件 ， 其 执行 结果 如 图 10.6 所 示 。 
通过 上 面 的 3 个 例子 ， 能 够 了 解 到 利用 GD 库 函 数 可 以 说 是 没有 做 不 到 ， 只 有 想不到 。 要 善于 利 
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用 库 函 数 来 实现 特定 的 目的 。 


R10% ~ 


10.6 ”使 用 画 直线 函数 绘制 正 十 二 角 星 


10.24 使 用 GD 库 函 数 在 图 片上 写字 


GE 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 10 章 \ 使 用 GD 库 函 数 在 图 片上 写字 .wmv 
本 节 将 使 用 imagestring() 函 数 在 一 张 已 经 存在 的 图 片上 写字 。 比较 常见 的 作用 是 当 用 户 把 图 片上 传 
到 服务 器 后 ， 通 过 PHP 程序 在 图 片上 打上 网 站 的 标记 ， 或 者 版 权 信息 。 该 函数 的 使 用 格式 如 下 所 示 : 


bool imagestring(resource image,int font,int x,int y,string s,int color) 


参数 image 为 一 个 已 经 打开 的 图 像 对 象 ， 参 数 x、y 为 整 型 变量 ， 


表示 已 经 打开 图 像 的 坐标 处 。 参 


数 font 为 整 型 变量 ， 内 容 为 要 显示 的 字体 。 如 果 要 使 用 中 文字 体 ， 则 要 把 该 字体 文件 放 到 程序 同一 个 


目录 下 。 参 数 string 为 字符 串 类 型 ， 内 容 即 为 要 写 的 文本 内 容 。 参 数 


color 为 整 型 变量 ， 内 容 为 欲 打印 


文本 的 颜色 。 函 数 的 返回 值 为 布尔 型 变量 ， 即 如 果 成 功 打 印 文本 则 返回 True， 和 否则 就 返回 False. 


【实例 10-7】 以 下 代码 演示 如 何 使 用 imagestring0 函 数 在 一 张 图 


c 实例 10-7: 使 用 imagestring() 函 数 在 一 张 图 片上 写字 
源码 路 径 : 光盘 \ 源 文件 \10\10-7.php 


01 <?php 

02 header("Content-type:image/jpeg"); 

03 Simage-"1 jpg"; 

04 S$imz-imagecreatefromjpeg($image); 

05 S$yellow-imagecolorallocate($im,255,255,0); 

06 S$white-imagecolorallocate($im, 255,255,255); 

07 imagestring($im,4,5,5,"I like this picture!",$yellow); 

08 imagestring($im,5,470,400,"Beautiful flowers",Swhite); 
09 imagejpeg(Sim); 

10 imagedestroy($im); 
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片上 写字 。 

/向 浏览 器 输出 文件 头 

// 定 义 变量 指向 图 像 文件 
/定义 黄色 

/定义 自 色 

// 用 黄色 在 图 片上 写字 
/用 自 色 在 图 片上 写字 
/| 输出 JPEG 

1/ 销毁 图 像 


zos Pea 0 


dies 


在 PHP 运行 环境 中 执行 该 PHP 文件 〈 在 执行 该 文件 之 前 ， 要 把 1.jpg 文件 放 到 同一 目录 下 ) , 
执行 结果 如 图 10.7 Pros. 


图 10.7 GD 库 函 数 在 图 片上 写字 


在 使 用 imagestring0 函 数 时 有 一 个 问题 需要 注意 ， 就 是 这 个 函数 不 支持 中 文 ， 即 string 参数 只 能 为 
英文 或 者 数字 ， 不 过 可 以 通过 安装 Freetype 字体 来 解决 这 个 问题 。 


10.2.5 使 用 GD 库 函 数 绘制 直方 统计 图 


GE 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 10 章 \ 使 用 GD 库 函 数 绘 制 直方 统计 图 .wmv 

前 两 小 节 读者 学 习 了 如 何 用 GD 库 函数 创建 图 像 及 如 何在 图 片 文件 上 输出 字符 。 本 小 节 为 读者 介 
绍 一 个 实用 的 例子 ， 用 GD 库 函 数 绘制 直方 统计 图 。 

【实例 10-8】 以 下 代码 演示 使 用 GD 库 函数 绘制 直方 统计 图 。 


01 <?php 

02 // 首 先 定义 一 个 数组 ， 其 内 容 可 以 表示 为 一 个 工厂 全 年 生产 效益 
03 S$num[0]-100; 
04 $num[1]=120; 
05 $num[2]=125; 
06 S$num[3]=130; 
07 S$num[4]-160; 
08 $num[5]-200; 
09 S$num[6]-230; 
10 $num[7]-250; 
11 S$num[8]-290; 
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12 $num[9]-310; 

13 $num[10]-400; 

14 $num[11]-200; 

15 header("Content-type: image/png"); // 输 出 头 文件 

16 $im=imagecreate(420,470); 

17 $black=imagecolorallocate($im, 0,0,0); /定义 黑色 

18 $whitezimagecolorallocate(Sim, 255,255,255); /定义 白色 

19 $yellow=imagecolorallocate($im,255,255,0); /定义 黄色 

20 $blue =imagecolorallocate($im,0,0,255); /定义 蓝 色 

21 $red-imagecolorallocate($im,255,0,0); /定义 红色 

22 imageline($im,5,5,5,435,$white); // 画 出 纵 坐 标 

23 imageline($im,5,435,400,435,$white); // 画 出 横 坐 标 

24 for($i=0;$i<count($num);$i++) // 循 环 画 出 直方 
25 imagefilledrectangle($im,($i+1)*30,440-$num[$i]-5, ($i+1)*30+20,435,$yellow); 
26 for($i-0;Si«count($num);Si--) // 循 环 画 出 数值 
27) imagestring(S$im,4,($i*1)*30,440-$num[$i]-5," $num[Si]",$blue); 

28 for($i=1;$i<13;$i++) // 循 环 画 出 横 坐标 单位 
29 imagestring($im,4,$i*30,440,"$i",$red); 

30 for($i=0;$i<5;$i++) UTER E H EK Ae s 88 nr 
31 { 

32 $s=$i*100; 

33 imagestring($im,4,5,435-$s,"$s",$white); 

34 } 

35 Imagepng($im); // 创 建 图 像 

36 Imagedestroy($im); /关闭 图 像 

37 ?> 
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图 10.8 使 用 GD 库 函 数 绘制 直方 统计 图 使 用 实例 执行 结果 
通过 以 上 实例 及 执行 结果 可 以 看 出 ,GD 库 函 数 配 合 数学 函数 可 以 画 出 功能 强大 的 数学 图 形 , 可 以 
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把 数字 内 容 变 为 直观 的 图 像 。 这 样 可 以 增加 程序 的 亲和力 ， 使 原本 枯燥 的 数字 使 用 户 更 容易 接受 ， 从 
而 增加 程序 的 易 用 性 。 


10.2.6 使 用 GD 库 函 数 创 建 图 像 的 缩 略图 


YA 知识 点 讲解 : 光盘 \ 视 频 讲 解 \ 第 10 章 \ 用 GD 库 函 数 创建 图 像 的 缩 略图 .wmv 

在 编写 Web 应 用 程序 时 ， 要 考虑 全 面 的 内 容 。 如 网 页 加 载 时 打开 的 图 像 太 大 ， 就 会 延长 网 页 打开 
的 速度 ， 从 而 会 使 用 户 失去 耐心 。 如 果 在 用 户 打开 图 片 前 ， 先 生成 和 欲 打开 图 像 的 缩 略 图 让 用 户 了 解 大 
致 情况 ， 就 会 改善 用 户 的 体验 。GD 库 函 数 就 有 创建 图 像 缩 略图 的 功能 。 本 小 节 就 来 介绍 如 何 使 用 GD 
库 函 数 创建 一 幅 图 像 的 缩 略 图 。 

在 介绍 程序 之 前 ， 先 来 认识 一 个 GD 库 函 数 : imagecopyresized0 函 数 。 它 的 使 用 格式 如 下 所 示 : 

int imagecopyresized(int dst im,int src_im,int dstX,int dstY,int srcX,int srcY,int dstW,int dstH,int srcW,int srcH); 

该 函数 可 以 复制 新 图 ， 并 重新 调整 图 片 的 大 小 尺寸 。 参 数 都 是 目的 在 前 ， 来 源 在 后 。 参 数 dst im 
及 sre. im 为 图 片 的 句柄 。 参 数 dstX、dstY、srcX、srcY 分 别 为 目的 及 来 源 的 坐标 。 参 数 dstW、dstH、 
srcW. srcH 分 别 为 来 源 及 目的 的 宽 和 高 ， 若 欲 调整 新 图 的 尺寸 就 在 这 里 设 定 。 

可 见 ， 通 过 此 函数 ， 就 可 以 达到 调整 图 片 大 小 的 目的 ， 生 成 缩 略 图 自然 也 是 可 以 的 。 

【实例 10-9】 以 下 代码 演示 使 用 imagecopyresized0 函 数 创建 图 像 的 缩 略 图 。 


re 实例 10-9， 使 用 imagecopyresized() 函 数 创建 图 像 的 缩 略 图 
t 源码 路 径 ， 光盘 \ 源 文件 \10\10-9.php 


01 <?php 

02 function resizeimage($srcfile,$rate=0.5) // 建 立 一 个 函数 以 指定 比率 缩放 图 像 
03 { 

04 $size=getimagesize($srcfile); 1/ 判断 图 片 类 型 及 大 小 

05 switch($size[2]) [ELEME EE EE dcn 
06 1 

07 case 1: 

08 Simg-imagecreatefromgif(Ssrcfile); 

09 break; 

10 case 2: 

11 S$img-imagecreatefromjpeg(Ssrcfile); 

12 break; 

13 case 3: 

14 Simg-imagecreatefrompng(Ssrcfile); 

15 break; 

16 ) 

17 $srcw-imagesx(S$img); // 源 图 片 的 宽度 

18 $srch=imagesy($img); // 源 图 片 的 高 度 

19 S$dstw-floor($srcw*Srate ); // 目 的 图 片 的 宽度 

20 $dsth=floor($srch*$rate); // 目 的 图 片 的 高 度 

21 $im=imagecreate($dstw,$dsth); /新 建 一 个 真 彩色 图 像 

22 $black=imagecolorallocate($im,255,255,255); /定义 黑色 

23 imagefilledrectangle($im,0,0,$dstw,$dsth,$black); / 画 一 个 图 色 的 矩形 

24 imagecopyresized($im,$img,0,0,0,0,$dstw,$dsth,$srcw,$srch); /重新 定义 新 图 像 
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25 imagejpeg($im); /以 JPG 格式 输出 新 图 像 

26 imagedestroy($im); /释放 源 图 像 

27 imagedestroy($img); /释放 目的 图 像 

28 H 

29 $im1-"1.jpg"; /定义 变量 

30 resizeimage($im1); // 调 用 函数 参数 $rate 使 用 默认 参数 
31 ?» 


注意 : 该 函数 的 参数 比较 多 ， 读 者 需要 热 知 每 个 参数 的 作用 。 


在 PHP 运行 环境 中 执行 以 上 代码 (注意 要 把 “1jpg” 放 到 同一 目录 下 ) ， 执 行 结 果 如 图 10.9 所 示 。 
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图 10.9 用 GD 库 函数 创建 图 像 的 缩 略 图 
通过 以 上 输出 的 图 像 ， 与 实际 使 用 的 “1;jpg” 的 比较 ， 发 现 程序 正确 输出 了 源 图 像 的 缩 略 版 ， 达 
到 了 创建 缩 略 图 的 目的 。 
从 上 面 的 函数 也 可 以 看 出 ， 通 过 此 函数 不 仅 可 以 创建 缩 略 图 ， 而 且 可 以 实现 图 像 的 任意 大 小 的 缩 
放 ， 可 见 其 功能 的 强大 。 
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本 章 为 读者 介绍 了 PHP 中 与 图 像 相 关 的 函数 及 GD 库 函 数 ， 重 点 介绍 了 GD 库 函 数 ， 通 过 几 个 实 
例 实际 地 使 用 了 几 个 常用 的 GD 库 函 数 。 本 章 知 识 点 有 : PHP 中 的 获取 图 像 信 息 函 数 getimagesize0， 
使 用 GD 库 函 数 创建 图 像 、 绘 制 几 何 图 形 、 在 图 片上 写字 等 。 通 过 本 章 的 学 习 ， 读 者 可 对 GD 库 函 数 
有 一 个 初步 的 了 解 。 更 深层 次 的 学 习 ， 就 需要 读者 在 实践 中 运用 所 学 知识 去 解决 实际 问题 。 


10.4 本 章 习 题 


习题 10-1 使 用 getimagesize() 函 数 获取 同 目录 下 test.jpg 图 像 文件 的 尺寸 并 输出 。 
【分 析 】 该 习题 考查 读者 对 getimagesize() 函 数 的 掌握 情况 。 
【关键 代码 】 


$size=getimagesize('test.jpg'); 


@ 
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echo "图 片 的 宽度 为 : {$size[0]}px"; 
echo "图 片 的 高 度 为 : {$size[1]}px"; 
2]88 10-2 ”使 用 iamgecreate() 函 数 创建 一 个 宽度 为 200px， 高 度 为 300px 的 画布 。 
【分 析 】 该 习题 考查 读者 对 创建 画布 函数 的 掌握 。 
【关键 代码 】 
header("Content-type:image/png"); 
S$im-imagecreate(200,300); 
习题 10-3 ”在 习题 10-2 的 基础 上 使 用 imagecolorallocate() 函 数 为 画布 填充 葛 色 。 
【分 析 】 该 习题 主要 考查 读者 对 创建 颜色 函数 的 掌握 。 
【关键 代码 】 
$blue =imagecolorallocate($im,0,0,255); 
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【关键 代码 】 
imagepng($im); 
imagedestroy($im); 
3]88 10-5 ”使 用 iamgeline() 函 数 绘制 如 图 10.10 所 示 的 图 形 ， 该 图 像 的 尺寸 为 150px X 300px . 
er 


图 10.10 执行 结果 


【分 析 】 该 习题 考查 读者 对 画 线 函数 的 掌握 以 及 熟练 应 用 的 能 
【关键 代码 】 


for($i=0;$i<200; $i++) 
imageline($im,100,100+$i,400,100+$i,$color2); 


输出 在 浏览 器 , 并 在 输出 后 清除 图 像 资源 。 
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编写 Web 互动 程序 ， 保 存 用 户 的 登录 信息 是 十 分 必要 的 ， 这 样 可 以 提高 网 站 对 用 户 的 吸引 力 。 目 
前 常见 的 存储 机 制 有 两 种 : 一 种 是 把 用 户 信息 存储 于 服务 器 端的 主机 上 的 Session 机 制 ; 另 一 种 是 把 用 
户 信息 存储 于 客户 端 即 客户 机 上 的 Cookie (小 甜 饼 ) 机 制 。 这 两 种 机 制 各 有 各 的 特点 ， 本 章 就 来 为 读 
者 介绍 PHP 中 的 Session 和 Cookie。 本 章 内 容 包括 : Session 的 使 用 注意 事项 、 有 关 的 Session 函数 及 
它们 的 使 用 方法 、Cookie 的 使 用 、PHP 中 的 Cookie 相关 函数 及 使 用 、 为 Cookie 设置 生命 期 、Cookie 
综合 运用 实例 。 


11.1 Session 的 使 用 


Session 适合 存储 信息 量 比较 少 的 用 户 信息 。 如 果 用 户 需要 存储 的 信息 量 相对 较 少 ， 并 且 对 存储 内 
容 不 要 求 长 时 间 存 储 时 ， 使 用 Session 把 信息 存储 于 服务 器 端 会 比较 适合 。Session 会 话 允 许 用 户 注册 
任意 数目 的 变量 并 保留 给 各 个 请 求 使 用 。 当 用 户 访问 网 站 时 ，PHP 会 自动 (如果 php.ini 中 的 
session.auto start 被 设 为 1) 或 在 用 户 请 求 时 〈 由 session_start() 明 确 调 用 或 session_register() 间 接 调用 ) 
检查 请 求 中 是 否 发 送 了 特定 的 会 话 ID。 如 果 是 ， 则 之 前 保存 的 环境 就 被 重建 。 本 节 就 为 读者 介绍 PHP 
中 Session 的 使 用 。 


11.1.1 ”如 何 使 用 Session 


C 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 11 章 \ 如 何 使 用 Session.wmv 
PHP 中 有 多 个 Session 函数 来 实现 对 Session 的 操作 。 有 了 这 些 函 数 , 使 用 Session 就 变 得 相当 简单 。 


表 11.1 常用 的 Session 相关 函数 


A 数 名 ft m 参数 及 返回 值 
此 函数 初始 化 一 个 新 的 | 该 函数 没有 参数 ， 且 返回 值 均 为 True。 需 要 
session start(void) Session， 若 该 客户 已 在 Session | 注意 的 一 点 是 在 session_start() 函 数 之 前 不 能 
之 中 ， 则 连 上 原 有 的 Session 有 任何 的 内 容 输出 ， 否 则 就 会 发 生 错误 
与 session_start() 函 数 一 样 ，ession_destroy() 函 
数 也 没有 参数 ， 且 返回 值 也 均 为 True 
若 无 可 选 参数 ，name 则 表示 仅 获取 目前 
Session 名 称 , 加 上 参数 则 表示 将 Session 名 称 
设 为 参数 name 


session destroy(void) 此 函数 结束 目前 的 Session 


本 函数 可 取得 或 者 重新 设 定 目 
前 Session 的 名 称 


session name(string [name]) 
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函 数 名 ff Hm 参数 及 返回 值 


若 无 可 选 参数 ，module 则 表示 只 获取 目前 
Session 的 模 组 , 加 上 参数 则 表示 将 Session 模 
组 设 为 参数 module 


本 函数 可 取得 或 者 重新 设 定 目 
前 Session 的 模 组 


session module name(string [module]) 


若 无 可 选 参数 ，path 则 表示 只 有 取得 目前 
Session 的 路 径 目 录 名 ， 加 上 参数 path 则 表示 
将 Session 存在 新 的 路 径 上 


本 函数 可 取得 或 者 重新 设 定 目 


session save path(string [path]) 前 存放 Session 的 路 径 


若 无 参 数 ，id 则 表示 只 有 取得 目前 Session 的 

sei e EH. | 代号 ， 加 上 参数 则 表示 将 Session 代号 设 成 
指定 的 id。 输入 及 传 回 均 为 字 串 

本 函数 可 将 Session 内 的 资料 | 参数 data 即 为 欲 解码 的 资料 。 成 功 则 传 回 True 

解码 值 ， 否 则 传 回 False 


session id(string [id]) 函 数 


session decode(string data) 


本 函数 可 将 Session 资料 编码 ， | 本 函数 没有 参数 。 成 功 则 传 回 True ff, FU 
编码 以 ZEND 引擎 做 杂凑 编码 | 传 回 False 


session encode(void) 


下 面 通过 一 个 实例 来 说 明 如 何在 PHP 中 使 用 Session. 


01 <?php 

02 session_start(); /开始 使 用 Session 
03 ?> 

04 «html» 

05 <head> 

06 <title>Session 使 用 实例 </title> 

07 </head> 

08 <body> 

09 <?php 

10 $username1="guest"; /定义 变量 

11 if(lisset($_SESSION["username"])) /判断 usemame 是 否 注册 成 功 
12 $_SESSION["usemame"]=$usemame1; /给 Session 变量 赋值 
13 echo $ SESSION['username"]; /显示 Session 

14 session destroy(); /| 结束 Session 

15 ?> 

16 </body> 

17 </html> 


在 PHP 运行 环境 中 执行 该 PHP 文件 (此 时 的 register_globals=on) ， 执 行 结果 如 图 11.1 所 示 。 


= 
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图 11.1 Session 使 用 实例 执行 效果 
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通过 上 面 的 实例 及 执行 结果 可 以 发 现 ， 程 序 正确 地 执行 了 相关 操作 。 它 的 运行 机 制 如 下 所 示 : FE 
序 先 判断 名 字 为 username 的 Session 有 没有 被 注册 。 如 果 没 有 则 注册 Session 变量 并 赋值 ， 然 后 把 名 字 
为 username 的 Session 变量 的 内 容 显示 出 来 。 


11.1.2. Session 使 用 实例 


FH 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 11 章 \Session 使 用 实例 .wmv 
上 面 的 实例 只 是 Session 最 简单 的 应 用 ， 实 际 上 Session 能 做 的 事情 远 不 止 于 此 ， 它 能 存储 多 种 信 
息 ， 结 合 程序 能 做 更 多 的 事情 。 
【实例 11-2】 以 下 代码 演示 使 用 Session 实现 一 个 简单 的 站 点 计数 器 。 
区 1" | 实例 11-2， 使 用 Session 实现 一 个 简单 的 站 点 计数 器 
源码 路 径 光盘 \ 源 文件 \11\11-2.php 


01 <?php 

02 session_start(); /开始 使 用 Session 

03 iflisset($_SESSION[count]) // 如 果 没 有 注册 Session 
04 $ SESSION['count]-1; /注册 Session 并 赋值 为 1 
05 else /如 果 已 经 注册 Session 
06 $ SESSION['count]**; /变量 在 原 有 基础 上 增加 1 
07 ?» 

08 «html» 

09 «head» 

10 «title» f& FB Session 的 网 页 计数 器 </title> 

11 </head> 

12 «body» 


<p> 
14 ”你 好 ， 你 已 经 浏览 本 网 页 <?php echo $ SESSION['count]; ?> 次 
15 </p> 
16 </body> 
17 </html> 
在 PHP 运行 环境 中 执行 该 PHP 文件 ， 执 行 结果 如 图 11.2 所 示 。 


ejua 


， 你 已 经 浏览 本 网 页 ?次 


图 11.2 使 用 Session 的 网 页 计数 器 执行 结果 
从 图 11.2 可 以 了 解 到 ， 该 页 面 注册 了 Session 变量 count。 并 且 随 着 刷新 ，count 的 值 也 随 之 增加 ， 
这 样 就 实现 了 统计 浏览 次 数 的 目的 。 
11.1.3 ”使 用 Session 的 注意 事项 


GR 知识 点 讲解 : 光盘 \ 视 频 讲 解 \ 第 11 章 \ 使 用 Session 的 注意 事项 .wmv 
在 使 用 Session 时 有 下 列 事项 需要 引起 注意 : 


[CN 
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如 果 在 php.ini 文件 中 启用 了 session.auto_start， 就 不 能 将 对 象 放 入 会 话 中 , 因为 类 定义 必须 在 

启动 会 话 之 前 加 载 以 在 会 话 中 重建 对 象 。 

请 求 结束 后 所 有 注册 的 变量 都 会 被 序列 化 。 已 注册 但 未 定义 的 变量 被 标记 为 未 定义 。 在 此 后 

的 访问 中 这 些 变量 也 未 被 会 话 模块 定义 ， 除 非 用 户 以 后 定义 它们 。 

另外 有 些 类 型 的 数据 不 能 被 序列 化 ， 因 此 也 就 不 能 保存 在 会 话 中 。 包 插 resource 对 象 类 型 变 

量 或 者 有 循环 引用 的 对 象 〈 即 某 对 象 将 一 个 指向 自己 的 引用 传递 给 另 一 个 对 象 )。 

默认 情况 下 ， 所 有 与 特定 会 话 相 关 的 数据 都 被 存储 在 由 php.ini 文件 的 session.save_path 选项 
所 指定 的 目录 下 的 一 个 文件 中 。 对 每 个 会 话 会 建立 一 个 文件 (不 论 是 否 有 数据 与 该 会 话 相关 )。 
这 是 由 于 每 打开 一 个 会 话 即 建立 一 个 文件 ， 不 论 是 否 有 数据 写 入 该 文件 中 。 注 意 由 于 和 文件 
系统 协同 工作 的 限制 ， 此 行为 有 个 副作用 ， 有 可 能 造成 用 户 定制 的 会 话 处 理 器 〈 如 用 数据 库 ) 
丢失 了 未 存储 数据 的 会 话 。 

Session 因为 是 存储 在 服务 器 端 ， 所 以 它 的 生命 期 是 很 短 的 。 注 册 过 的 变量 经 过 一 定 的 时 间 后 
就 会 自动 失效 。 


加 
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11.2 Cookie 的 使 用 


11.1 节 给 读者 介绍 了 PHP 中 关于 Session 的 使 用 ， 本 节 来 为 读者 介绍 PHP 中 Cookie 的 使 用 。 通 过 
本 节 的 学 习 ， 读 者 可 对 PHP 中 的 Cookie 的 使 用 有 一 个 深刻 的 理解 ， 并 且 能 够 使 用 Cookie 去 实际 处 理 
一 些 问题 。 


11.2.1 为 什么 使 用 Cookie 


(UE 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 11 章 \ 为 什么 使 用 Cookie wmv 
同样 作为 互动 Web 页 的 存储 机 制 ，Cookie 与 Session 有 其 相似 之 处 。 那 为 什么 在 有 了 Session 后 还 
要 使 用 Cookie 呢 ? 因为 同 Session 相 比 Cookie 有 其 独特 之 处 。 下 面 就 来 说 明 一 下 二 者 的 异同 ， 比 较 过 
二 者 的 异同 后 ， 读 者 就 会 明白 为 什么 要 用 Cookie 了 。 
Cookie 保存 在 客户 端 ， 而 Session 的 内 容 保存 在 服务 器 端 ， 只 是 把 一 个 session id 保存 在 客户 
端 。 也 就 是 说 , Session 比 Cookie 更 安全 , 同时 也 可 以 说 明 Session 是 基于 Cookie 的 (用 Cookie 
来 保存 session id). 
由 于 Session 是 保存 在 服务 器 端的 ， 因 此 会 占用 服务 器 的 空间 ， 所 以 一 般 在 一 定时 间 内 没有 活 
动 时 Session 就 会 过 期 ， 而 且 在 浏览 器 关闭 后 也 会 作废 。 而 Cookie 就 没有 这 方面 的 限制 ， 它 
可 以 设 定 一 个 比较 长 的 过 期 时 间 。 
有 些 人 会 禁止 浏览 器 接收 Cookie， 而 此 时 Session 还 是 可 以 用 的 (注意 Session 也 可 以 不 通过 
Cookie 来 实现 )。 
通过 以 上 比较 可 以 发 现 : Cookie 与 Session 各 有 各 的 用 处 ， 各 有 各 的 特点 ， 两 者 不 能 够 相互 替代 。 
11.22 小 节 就 来 了 解 一 下 ， 在 PHP 中 如 何 使 用 Cookie。 


加 
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KA aaa 


11.2.2 ”怎样 使 用 Cookie 
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在 PHP 中 使 用 Cookie 相当 简单 ， 简 单 到 只 用 一 名 函数 就 可 以 注册 Cookie 变量 。 这 个 函数 是 
setcookie()， 其 使 用 格式 如 下 所 示 : 

bool setcookie(string name[string value[int expire[string path[string domain[bool secure[bool httponlyJ]]]] ) 

该 函数 会 跟着 文件 头 信息 header 送出 一 段 信息 字符 串 到 浏览 器 。 由 于 是 同 header 一 起 发 送 ， 所 以 该 
函数 同 其 他 header 函数 一 样 ， 在 执行 前 不 能 有 任何 的 HTML 输出 。 实 际 上 Cookie 也 算 报头 的 一 部 分 。 

setcookie() 函 数 的 参数 除了 第 一 个 name 之 外 ， 都 是 可 以 省 略 的 。 参 数 name 表示 Cookie 的 名 称 ; 
value 表示 这 个 Cookie 的 值 ,value 参数 为 空 字 串 则 表示 取消 浏览 器 中 名 称 为 name 的 Cookie 变量 的 值 ; 
expire 表示 该 Cookie 的 有 效 时 间 ; path 为 该 Cookie 的 相关 路 径 ，domain 表示 Cookie 的 网 站 ; secure 
则 需 在 https 的 安全 传输 时 才 有 效 。 
注意 : 要 设置 的 过 期 时 间 通 常 要 在 当前 时 间 的 基础 上 进行 增加 。 

以 下 代码 演示 如 何在 PHP 中 使 用 Seo CUN NOE REHE Cookie. 


7] “实例 11-3， 如 何在 PHP 中 使 用 setcookie0 函 数 来 定义 并 使 用 Cookie — 
源码 路 径 ， 光盘 \ 源 文件 \11\11-3.php 


01 <?php 

02 $username-$ GET['username"]; // 通 过 URL 获得 参数 

03 if$ GET['username"]) /如 果 没 有 参数 执行 内 容 
04 { 

05 setcookie("username",""); /取消 usemame 的 资料 
06 echo "没有 指定 用 户 名 !"; 

07 echo "«p»"; 

08 echo "或 者 用 户 名 不 存在 !"; 

09 } 

10 else // 如 果 存 在 参数 

11 ( 

12 setcookie("username","$username"); IFSERRFR P 

13 echo "注册 成 功 ， 点 <a href=11-4.php> 这 里 </a> 查 看 ";  ”// 显 示 链接 以 查看 Cookie 信息 
14 } 

15 ?> 

16 <html> 

17 <head> 

18 ”<title> 注 册 用 户 信息 </title> 

19 </head> 

20 <body> 

21 </body> 

22 </html> 

保存 下 面 的 代码 为 11-4.php: 

01 <html> 
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02 <head> 

03 ”<title> 显 示 用 户 信息 </title> 

04 </head> 

05 <body> 

06 <?php 

07 echo "注册 用 户 名 为 :"; 

08 echo $ COOKIE['username]; /显示 Cookie 信息 
09 ?> 

10 </body> 

11 «html» 


在 PHP 运行 环境 中 执行 实例 11-3 中 的 文件 ， 不 带 任何 参数 ， 执 行 结果 如 图 11.3 所 示 。 
如 果 加 上 username 参数 ， 如 11-3.php?usemame-guest 再 次 运行 ， 效 果 就 会 不 一 样 ， 执 行 结果 如 图 
11.4 所 示 。 
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[€] NE rtp:ilocaltesti £ 
没有 指定 用 户 名 ! 
或 者 用 户 名 不 存在 ! 
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@ 
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R100% - 
图 11.3 不 带 参 数 执行 11-3.php 的 结果 图 11.4 加 上 参数 后 执行 11-3.php 的 结果 


这 里 已 经 把 username 注册 为 Cookie， 其 值 为 guest， 然 后 单 击 “ 这 里 ”链接 ， 将 会 出 现实 例 11-4 
的 执行 情况 ， 如 图 11.5 所 示 。 


calhost/11 £ 


图 11.5 11-4.php 的 执行 结果 


图 11.5 显示 出 了 所 注册 的 用 户 名 ， 说 明 Cookie 已 经 设置 成 功 。 由 于 没有 给 Cookie 设置 生命 期 ， 
所 以 该 Cookie 的 值 会 随 着 浏览 器 的 关闭 而 中 止 。 所 以 如 果 要 保持 Cookie 的 值 长 期 有 效 ， 为 其 设置 生 
命 期 是 有 必要 的 。 


11.2.3 i&& Cookie 生命 期 


GERD 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 11 章 \ 设 置 Cookie 生命 期 -wmv 

在 实际 使 用 PHP 编写 Web 应 用 程序 时 ， 为 了 方便 用 户 ， 需 要 对 Cookie 设置 生命 期 。 如 有 的 论坛 
在 登录 时 就 会 有 个 选择 : 保存 用 户 登录 记录 ， 并 且 还 可 以 设置 时 间 ， 如 保存 一 个 月 、 三 个 月 、 甚 至 是 
一 年 5 

其 实 保存 用 户 登录 记录 的 实质 就 是 保存 了 用 户 的 登录 信息 到 客户 机 上 ， 并 且 为 该 Cookie 设置 了 较 
长 的 生命 期 这样 就 避免 了 用 户 再 次 登录 时 ， 需 要 重新 输入 登录 信息 的 问题 。 

如 何 为 Cookie 设置 生命 期 ? 11.2.2 小 节 中 讲 到 setcookie0O) 函 数 时 就 提 到 了 这 个 问题 ， 就 是 函数 的 
第 三 个 参数 : expire， 它 的 作用 就 是 为 Cookie 设置 生命 期 。 如 果 这 一 项 为 室 ， 就 说 明 最 短 生命 期 即 随 
着 浏览 器 的 关闭 而 中 止 。 那 么 只 要 带 有 expire 参数 ， 就 说 明 要 为 Cookie 设置 生命 期 ， 其 单位 为 日 期 和 
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时 间 ， 一 般 采用 如 下 代码 : 

time()+N 

其 中 的 time0 表 示 当 前 时 间 ， 后 面 的 N 表示 秒 数 。timeO+N 的 意思 就 是 在 当前 时 间 后 多 少 秒 过 期 。 
如 果 要 设置 过 期 时 间 为 一 天 代码 如 下 : 

setcookie(name,value,time()+60*60*24); 

其 中 的 60*60*24 即 表示 一 天 。 以 上 代码 即 表 示 设 置 Cookie 变量 name 的 值 为 value， 有 效 期 为 从 
当前 时 间 起 24 小 时 ， 即 一 天 一 夜 。 

知道 了 如 何 设置 一 天 ， 那 么 ， 设 置 一 个 月 ， 甚 至 一 年 都 非常 容易 了 。 如 设置 有 效 期 为 一 个 月 代码 
如 下 : 

setcookie(name,value,time()+60*60*24*30); 

同 理 ， 设 置 一 年 有 效 期 代码 如 下 : 

setcookie(name,value,time()+60*60*24*30*365); 

至 此 ， 相 信 读 者 对 如 何 为 Cookie 设置 生命 期 都 有 了 一 个 深刻 的 理解 。11.2.4 小 节 就 为 读者 介绍 一 
个 综合 应 用 的 实例 ， 来 实际 操作 一 下 Cookie。 


11.2.4 Cookie 综合 应 用 实例 一 一 网 页 风格 转换 
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通过 前 几 小 节 的 介绍 ， 读 者 对 PHP 中 如 何 使 用 Cookie 有 了 一 个 比较 深刻 的 了 解 。Cookie 常用 于 
用 户 登 录 记 录 、 相 关 设 置 记录 等 ， 本 小 节 的 实例 就 来 为 读者 演示 这 个 问题 。 

【实例 11-4】 以 下 代码 为 前 台 界 面 代码 。 


<head> 
<title> 用 户 登录 前 台 </tile> 
</head> 
<body topmargin-"20"> 
<center> 
<table border=1> 
«form method-post action-11-6.php» 
<tr> 
<td> 请 输入 用 户 名 : </td> 
<td><input type=text name-username size=20></td> 
«itr» 


«tr» 

<td> 请 输入 密码 : </td> 

<td><input type=password name=password size-20»«/td» 
«ftr» 
«tr» 
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18 <td> 请 选择 保存 期 限 : </td> 

19 «td» 

20 «select name-time size- 1» 

21 «option value=1> 不 保存 
22 «option value=2> 保 存 一 天 
23 <option value=3> 保 存 一 月 
24 <option value=4> 保 存 一 年 
25 </select> 

26 </td> 

27 «Ite 

28 «tr» 


29 <td colspan-2»«input type=submit value-" ifi zE"» «/td» 


30 «ltr» 
31 </form> 
32 </table> 

33 </center> 

34 </body> 

35 <html> 


【实例 11-5】 以 下 代码 为 后 台 执行 代码 。 


实例 11-5: 后 台 执行 代码 
源码 路 径 : 光盘 '\ 源 文件 \11\11-6.php 


01 <?php 

02 $username=$_POST["username"]; 
03 $time-$ POST['time"]; 

04 ifisset$ POST['usemame"])) 

05 ( 

06 switch ($time) 

07 ( 

08 case 1: 

09 $ctime-""; 

10 break; 

11 case 2: 

12 $ctime-60*60*24; 

13 break; 

14 case 3: 

15 $ctime-60*60*24*30; 
16 break; 

17 case 4: 

18 $ctime-60*60*24*365; 
19 break; 

20 ) 

21 setcookie("username",$username,time()* $ctime); 
22 setcookie("time",$time); 

23 } 

24 else 

25 { 

26 echo "没有 输入 用 户 名 "; 

27 echo "<p>"; 


// 通 过 POST 获得 参数 
/通过 POST 获得 time 变量 
// 如 果 没 有 参数 ， 执 行内 容 


// 判 断 有 效 期 


/注册 用 户 名 
/注册 过 期 时 间 


/如 果 存 在 参数 


Nie Re 


28 echo "点 <a href=11-5.php> 这 里 </a> 返 回 "; 

29 h 

30 ?» 

31 <head> 

32 «meta http-equiv-"refresh" content-"O;url-http://localhost/11-7.php"» 
33 </head> 


【实例 11-6】 以 下 代码 用 于 输出 注册 信息 。 


re 实例 11-6: 输出 注册 信息 
源码 路 径 光盘 \ 源 文件 \11\11-7.php 


01 <html> 

02 <head> 

03 ”<title> 注 册 用 户 信息 </title> 

04 </head> 

05 <body> 

06 <?php 

07 echo "注册 用 户 名 为 : "; 

08 echo $ COOKIE['username']; 

09 echo "<br /»Cookie 有 效 期 为 :"; 

10 switch ($ COOKIE[time"]) 

11 { 

12 case 1: 

13 echo "不 保存 "; 

14 break; 

15 case 2: 

16 echo "一 天 "; 

17 break; 

18 case 3: 

19 echo "一 月 "; 

20 break; 

21 case 4: 

22 echo "—££"; 

23 break; 

24 ) 

25 ?> 

26 </body> 

27 </html> 

在 PHP 运行 环境 中 执行 实例 11-4 中 的 代码 ， 执 行 结果 如 图 11.6 所 示 。 
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图 11.6 11-4.php 执行 结果 


1 


然后 ， 按 照 上 面 内 容 输 入 用 户 名 、 密 码 (因为 只 是 测试 Cookie， 所 以 其 实 这 两 项 都 是 虚 的 ， 并 不 
存在 用 户 数据 库 ， 只 要 输入 有 内 容 就 行 ) 。 并 选择 相应 的 Cookie 保存 期 限 ， 然 后 单 击 “ 确 定 ”按钮 ， 


程序 开始 启用 后 台 操 作 并 跳 转 到 注册 信息 界面 ， 执 行 结果 如 图 11.7 所 示 。 


图 11.7 后 台 处 理 后 的 执行 结果 


以 上 就 是 Cookie 用 于 简单 的 用 户 注 册 登 录 ， 并 保存 用 户 记录 的 情况 。 下 面 再 介绍 一 个 实例 ， 用 
Cookie 保存 用 户 选择 的 网 站 风格 。 某 些 网 站 或 者 论坛 具有 多 种 风格 供用 户 选 择 ， 这 样 可 以 满足 用 户 不 


同 的 需求 。 
下 面 就 介绍 如 何 用 Cookie 来 实现 改变 网 站 的 风格 。 
【实例 11-7】 以 下 代码 为 主页 面 ， 该 文件 中 大 部 分 内 容 均 为 标准 的 HTML 内 容 。 


re 实例 11-7， 主 页 面 代码 
源码 路 径 光盘 \ 源 文件 \11\11-8.php 


01 <html> 

02 <head> 

03 title» FH cookie 实现 改变 网 站 风格 </title> 

04 <?php 

05 echo "<LINK href='style".$_COOKIE["style"].".css' rel=stylesheet>"; // 根 据 Cookie 使 用 样式 
06 ?> 

07 </head> 

08 <body> 

09 <table> 

10 <p> 用 Cookie 实现 改变 网 站 风格 </p> 

11 <tr> 

12 <td><a hre 作 11-9.php?style=1> 风 格 1«/a»«/td» 
13 <td><a href=11-9.php?style=2> 风 格 2</a></td> 
14 <td><a hre 作 11-9.php?style=3> 风 格 3</a></td> 
15 <td><a href=11-9.php> 无 样式 </a></td> 

16 E 

17 <tr> 

18 <td colspan=4><h1> $ RE«/h12«/td» 

19 </tr> 

20 <tr> 

21 «td colspan-4» «h2» # 387 7c 81 «/h27 «/td» 

22 </tr> 

23 <tr> 

24 «td colspan=4><h2> 了 明镜 亦 非 台 </h2></td> 

25 «It» 

26 <tr> 

27 <td colspan=4><h2> 本 来 无 一 物 </h2></td> 

28 «itr» 

29 <tr> 
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30 «td colspan=4><h2> 何 处 若 尘埃 </h2></td> 
31 </tr> 

32 </table> 

33 </body> 

34 </html> 


【实例 11-8】 以 下 代码 为 处 理 提交 样式 的 PHP 文件 ， 其 功能 是 根据 提交 内 容 注 册 相应 的 Cookie。 


实例 11-8: 处 理 提交 样式 
源码 路 径 光盘 \ 源 文件 \11\11-9.php 


01 <?php 

02 $style=$_GET["style"]; // 判 断 参 数 来 源 
03 setcookie("style","$style"time()*60*60*24); /根据 参数 注册 Cookie 
04 ?> 

05 «html» 

06 <head> 

07 ”<title> 正 在 处 理 </title> 

08 </head> 

09 <meta http-equiv="refresh" content="0; url=11-8.php"> 

10 «body» 

11 ”正在 处 理 

12 </body> 


另外 在 使 用 这 个 实例 之 前 还 要 编写 相应 的 CSS 文件 ， 并 命名 为 stylel.css、style2.css、style3.css。 


这 3 个 css 文件 的 内 容 如 下 所 示 : 
stylel.css: 
BODY, TD ( 
font : 400 normal 100% Arial, Helvetica, sans-serif; 
) 
Af 
color: #FFD700; 
text-decoration: none; 
background: Black; 
width: 80px; 
padding: 3px; 
} 
A:hover 
{ 
background: Maroon; 
H1( 
background: #228B22 none; 
color: #FF6347; 
font-size: 15096; 
text-align: right; 
) 


H2{ 
background : #FFDEAD none; 
color : #000000; 
font-size : 110%; 


H 

PA 
background: #A9A9A9 none; 
color: #2F4F4F; 
font: 400 normal 120% Arial, Helvetica, sans-serif; 
text-decoration: none; 
padding: 2% 2% 2% 2%; 
border: 1px solid Black; 

) 

style2.css: 

body ( 
background-color: #FFFFFO; 

) 

at 
background: 4FFFFAA; 
text-decoration: none; 

) 

a:hover ( 
background: 4&FFFFFO; 
border: thin solid Black; 

} 

hif 
text-align: center; 

} 

h2( 
text-align: center; 

) 

pt 
text-align: center; 
font-size: 20px; 

) 

style3.css: 

body ( 
background-color: #FFFFFO; 
background-image: url(image001.jpg); 

ii 

a{ 
text-decoration: none; 
background-color: #0000CD; 
color: White; 
font-size: 15px; 

} 
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a:hover ( 
background-color: Maroon; 

H 

hit 
text-align: center; 
background-color: €FAFAD2; 


color: Blue; 
H 
n2( 
text-align: center; 
background-color: #F5F5DC; 
color: Green; 
border: 1px solid Black; 
) 
pt 
text-align: center; 
border: 5px ridge; 
font-size: 40px; 
) 


说 明 : 关于 css 的 知识 本 书 不 做 讲解 ， 读 者 可 以 参考 相关 书籍 。 


由 于 style3.css 使 用 了 图 片 作为 背景 ， 所 以 要 把 名 称 为 image001.jpg 的 图 片 放 到 该 ess 文件 的 同一 
个 目录 下 。 一 切 准 备 就 络 ， 先 执行 实例 11-8， 执 行 结 果 如 图 11.8 所 示 。 

由 于 此 时 并 没有 名 为 style 的 Cookie 变量 存在 ， 所 以 现在 不 使 用 任何 样式 。 

单 击 “ 风 格 1” 链 接 后 ， 实 例 11-8 将 注册 Cookie 值 为 1 的 变量 style， 此 时 网 页 的 效果 如 图 11.9 


所 示 。 
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图 11.8 首次 执行 实例 11-8 时 的 执行 图 11.9 使 用 风格 1 的 效果 


同 理 分 别 单 击 “ 风 格 2”、“ 风 格 3” 链接， 都 会 采用 相应 的 样式 文件 ， 执 行 结果 分 别 如 图 11.10 
和 图 11.11 所 示 。 


如 果 单 击 “ 无 样式 ”链接 ， 由 于 没有 参数 style， 所 以 实例 11-8 中 的 setcookie 一 句 的 第 二 个 参数 为 
空 ， 此 时 即 为 中 止 使 用 Cookie 变量 style。 即 此 时 的 style 无 效 ， 所 以 返回 的 结果 同 第 一 次 打开 时 相同 。 


他 
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图 11.10 使 用 风格 2 的 效果 图 11.11 使 用 风格 3 的 效果 
-x— 
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本 章 为 读者 介绍 了 PHP 中 的 两 种 存储 用 户 信息 的 机 制 : Session 和 Cookie。 通 过 本 章 的 学 习 ， 读 
者 可 对 使 用 这 两 种 方式 存储 用 户 信息 有 一 个 比较 深刻 的 认识 。 其实 不 管 是 采用 Session 作为 存储 的 载体 
或 者 采用 Cookie 作为 存储 的 载体 , 关键 要 看 怎么 用 。 二 者 互 有 特点 , 有 时 也 可 以 把 二 者 结合 起 来 使 用 ， 
取长补短 ， 使 自己 用 PHP 编写 的 Web 程序 更 稳定 、 更 友好 。 
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习题 11-1 创建 一 个 Session 变量 name， 它 的 值 为 Tom. 
【分 析 】 该 习题 主要 考查 读者 对 Session 最 基本 使 用 方式 的 掌握 。 
【关键 代码 】 
session start(); 
$ SESSION[name]- Tom'; 
习题 11-2 创建 一 个 新 的 页 面 ， 并 且 在 该 页 面 中 输出 习题 从 1 中 Session 变量 name 的 值 。 
【分 析 】 该 习题 考查 读者 对 页 面 间 传 递 Session 变量 的 掌握 。 
【关键 代码 】 
echo $ SESSION[name7; 


习题 11-3 ”创建 一 个 Cookie 变量 psw， 它 的 值 为 goodo 
【分 析 】 该 习题 主要 考查 读者 对 Cookie 变量 使 用 方式 的 掌握 。 
【关键 代码 】 
setcookie('psw','good'time()*60*10); 
习题 114 ”创建 一 个 新 的 页 面 ， 并 且 在 该 页 面 中 输出 习题 11-3 中 Cookie 变量 psw 的 值 。 
【分 析 】 该 习题 考查 读者 对 Cookie 变量 使 用 方式 的 掌握 。 
【关键 代码 】 
echo $_COOKIE[psw]; 
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1r $ PHP 中 正则 表达 式 的 使 用 


正则 表达 式 在 PHP 编程 中 有 着 相当 广泛 的 应 用 ， 它 可 以 实现 对 特定 内 容 的 查找 和 替换 。 很 多 人 因 
为 它们 看 上 去 比较 古怪 而 且 复 杂 所 以 不 敢 去 使 用 。 不 过 ， 经 过 一 点 点 练习 之 后 就 会 发 现 这 些 复杂 的 表 
达 式 其 实 写 起 来 还 是 相当 简单 的 。 而 且 ， 一 旦 弄 懂 它 们 就 能 把 数 小 时 辛苦 而 且 易 错 的 文本 处 理工 作 压 
缩 在 儿 分 钟 ( 甚 至 儿 秒 钟 ) 内 完成 。 本 章 就 带领 读者 来 学 习 PHP 中 的 正则 表达 式 。 本 章 内 容 包括 : fF 
么 是 正则 表达 式 、 如 何 使 用 模式 匹配 、 正 则 表达 式 语 法 、Perl 兼容 的 正则 表达 式 函 数 、 正 则 表达 式 使 
用 实例 等 。 本 章 的 学 习 会 使 读者 揭 去 正则 表达 式 神秘 的 面纱 ， 一 睹 它 的 风采 。 


12.1 关于 正则 表达 式 


本 节 将 介绍 关于 正则 表达 式 的 基础 性 问题 ， 让 读者 了 解 究竟 什么 是 正则 表达 式 、 正 则 表达 式 由 什 
么 元 素 组 成 、 如 何 使 用 正则 表达 式 等 。 通 过 本 节 的 学 习 ， 读 者 会 对 正则 表达 式 有 一 个 比较 全 面 的 了 解 。 


12.1.1 什么 是 正则 表达 式 


F 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 12 章 \ 什 么 是 正则 表达 式 .wmv 

简单 地 说 ， 正 则 表达 式 就 是 一 个 字符 构成 的 串 ， 它 定义 了 一 个 用 来 搜索 匹配 字符 串 的 模式 。 它 的 
作用 是 实现 用 正则 表达 式 模式 对 一 个 字符 串 中 特定 的 字符 或 字符 集合 进行 查找 与 替换 。 正 则 表达 式 由 
一 些 普通 字符 和 一 些 元 字符 〈metacharacters) 组 成 ， 它 包含 一 个 正则 表达 式 模式 。 正 则 表达 式 中 普通 
字符 包括 大 小 写字 母 和 数字 ， 大 多 数字 字符 在 模式 中 表示 它们 自身 并 匹配 目标 中 相应 的 字符 ， 而 元 字 
符 则 具有 特殊 的 含义 ， 后 面 会 给 予 解释 。 

例如 ， 判 断 邮政 编码 是 否 合法 的 正则 表达 式 为 ; 

ereg("^(10-9K6}-[0-915})?$") 

Jtr *0-9" . "6". "s" 为 普通 字符 ，“^”、“[]”、“?”、“$” 等 为 元 字符 。 

正则 表达 式 的 作用 在 于 其 能 够 在 模式 中 包含 选择 和 循环 ， 它 们 通过 使 用 元 字符 来 编码 ， 元 字符 不 
代表 其 自身 ， 它 们 用 一 些 特殊 的 方式 来 解析 。 

有 两 种 不 同 的 元 字符 : 一 种 是 模式 中 除了 方 括号 内 都 能 被 识别 的 ， 还 有 一 种 是 在 方 括号 内 被 识别 
的 ， 下 面 分 别 作 一 介绍 。 

方 括号 之 外 的 元 字符 有 以 下 内 容 ， 如 表 12.1 所 示 。 
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R121 正则 表达 式 中 的 元 字符 列表 


元 字 符 | 用 在 方 括号 内 /外 作 m 
M 人 有 数 种 用 途 的 通用 转 义 符 
^ 人 匹配 字符 串 的 开始 (或 在 多 行 模式 下 行 的 开头 ， 即 紧 随 在 换行 符 之 后 ) 
$ 5| 匹配 字符 串 的 结尾 或 在 多 行 模式 下 行 的 结尾 ， 即 紧 随 在 换行 符 之 前 ) 
à 5| 匹配 除了 换行 符 外 的 任意 一 个 字符 〈 默 认 情况 下 ) 
Í 多 字符 类 定义 开始 
] 4| 字符 类 定义 结束 
| 4| 开始 一 个 多 选 一 的 分 支 
( Di 子 模式 开始 
) Li 子 模式 结束 
? 5| 扩展 “(” 的 含义 ， 也 是 0 或 1 数量 限定 符 ， 以 及 数量 限定 符 最 小 值 
* 5| 匹配 0 个 或 多 个 数量 限定 符 
十 4| 匹配 1 个 或 多 个 数量 限定 符 
{ 4| 最 少 / 最 多 数量 限定 开始 
4| 最 少 / 最 多 数量 限定 结束 
\ 内 通用 转 义 字符 
^ 内 排除 字符 类 〈 逻 辑 非 ) ， 但 仅 当 其 为 第 一 个 字符 时 有 效 
- 内 指出 字符 范围 
] 内 结束 字符 类 


K 12.1 中 列 出 的 模式 在 方 括号 内 使 用 的 部 分 称 为 “字符 类 ”。 

在 以 上 介绍 的 儿 种 元 字符 中 ， 反 斜 线 是 一 类 特殊 的 字符 ， 反 和 斜 线 字 符 有 4 种 用 法 。 

第 一 种 用 法 就 是 在 它 后 面 跟 上 非 字母 或 数字 的 特殊 符号 来 代替 这 些 特殊 符号 本 身 。 此 种 将 反 斜 线 
用 作 转 义 字符 的 用 法 适用 于 两 种 情况 , 即 不 论 是 方 括号 之 内 还 是 方 括号 之 外 都 适用 。 如 要 匹配 一 个 “*” 
字符 ， 则 在 模式 中 用 “\*”。 这 适用 于 无 论 下 一 个 字符 是 否 会 被 当 作 元 字符 来 解释 ， 因 此 在 非 字母 或 
数字 字符 之 前 加 上 一 个 “\” 来 指明 该 字符 就 代表 其 本 身 总 是 安全 的 。 尤 其 是 ， 如 果 要 匹配 一 个 反 斜 线 ， 
Hw. 

第 二 种 用 法 是 提供 了 一 种 在 模式 中 以 可 见方 式 去 编码 不 可 打印 字符 的 方法 ， 并 没有 不 可 打印 字符 
出 现 的 限制 ， 除 了 代表 模式 结束 的 二 进 制 零 以 外 。 但 用 文本 编辑 器 来 准备 模式 时 ， 通 常用 以 下 的 转 义 
序列 来 表示 那些 二 进 制 字符 更 容易 一 些 ， 如 表 12.2 所 示 。 


5122 反 斜 线 通常 用 到 的 转 义 序列 所 表示 的 二 进 制 字符 列表 


转 义 字符 所 表示 的 二 进 制 字符 
la alarm, Bl BEL 字符 (0x07) 
wa “control-x”， 其 中 x 是 任意 字符 
Ye escape (Ox1B) 
iu 换 页 符 formfeed (0x0C) 
\n 换行 符 newline (0x0A) 
Ww 回 车 符 carriage retum (Ox0D) 
X 制 表 符 tab (0x09) 
\xhh 十 六 进 制 代码 为 hh 的 字符 


KA aaa 


Hk 

转 义 字符 所 表示 的 二 进 制 字符 

\ddd 八进制 代码 为 ddd 的 字符 ， 或 backreference 

\040 另 一 种 表示 空格 的 方法 

M0 同上 ， 如 果 之 前 捕获 的 子 模式 少 于 40 个 的 话 

n 总 是 一 个 逆向 引用 

MI 可 能 是 个 逆向 引用 ， 或 者 是 制 表 符 tab 

\011 总 是 表示 制 表 符 tab 

10113 表示 制 表 符 tab 后 面 跟着 一 个 字符 “3” 

M13 表示 八进制 代码 为 113 的 字符 (因为 不 能 超过 99 个 逆向 引用 ) 

977 表示 一 个 所 有 的 比特 都 是 1 的 字 节 

\81 要 么 是 一 个 逆向 引用 ， 要 么 是 一 个 二 进 制 的 零 后 面 跟着 两 个 字符 “8” 和 “1” 


注意 : 八进制 值 的 100 或 大 于 100 的 值 之 前 不 能 以 零 打头 ,因为 不 会 读 取 ( 反 斜 线 后 ) 超过 3 个 八进制 数字 。 


所 有 定义 了 一 个 单 
被 解释 为 反 斜 线 字符 
反 斜 线 的 第 三 种 用 
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\D: 任 一 非 十 


\w: 任 一 “ 字 


国力 图 回回 
Nn 


反 斜 线 的 第 四 种 用 
不 会 消耗 目标 字符 串 中 


Wb 

\B: 非 字 分 界 
V 目标 的 结 
v 


RARRARA 


iG: 目标 中 的 


: 字 分 界线 。 


一 字 节 的 序列 可 以 用 于 字符 类 之 中 或 之 外 。 此 外 ， 在 字符 类 之 中 ， 序 列 “\b” 
0x08) ， 而 在 字符 类 之 外 有 不 同 含义 〈 见 下 面 ) 。 
法 是 指定 通用 字符 类 型 : 


\d: 任 一 十 进 制 数 字 。 


进 制 数 的 字符 。 


wi 任 一 空白 字符 。 
: 任 一 非 空 白字 符 。 


”的 字符 。 


Ww. 任 一 “ 非 字 ” 的 字符 


法 是 某 些 简单 的 断言 。 断 言 是 指 在 一 个 匹配 中 的 特定 位 置 必须 达到 的 条 件 ， 并 
的 任何 字符 。 反 和 斜 线 的 断言 有 : 


头 〈 独 立 于 多 行 模式 )。 
尾 或 位 于 结尾 的 换行 符 前 《独立 于 多 行 模式 )。 


: 目标 的 结尾 〈 独 立 于 多 行 模式 )。 


第 一 个 匹配 位 置 。 


这 些 断 言 可 能 不 能 出 现在 字符 类 中 (但 是 注意 “\b” 有 不 同 的 含义 ， 在 字符 类 之 中 也 就 是 反 斜 线 


字符 ) 。 


12.1.2 ”如 何 使 用 模式 匹配 


G 知 识 点 讲解 : 


光盘 \ 视 频 讲 解 \ 第 12 章 \ 如 何 使 用 模式 匹配 .wmv 


12.1.1 节 为 读者 介绍 了 什么 是 正则 表达 式 , 及 表达 式 中 的 元 字符 。 本 小 节 就 来 介绍 如 何 使 用 匹配 模 
式 。 模 式 是 正则 表达 式 最 基本 的 元 素 ， 它 们 是 一 组 描述 字符 串 特征 的 字符 。 模 式 可 以 很 简单 ， 由 普通 


的 字符 串 组 成 ， 也 可 以 


(m, 


非常 复杂 ， 往 往 用 特殊 的 字符 表示 一 个 范围 内 的 字符 重复 出 现 ， 或 表示 上 下 文 。 
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在 最 简单 的 情况 下 ， 一 个 正则 表达 式 看 上 去 就 是 一 个 普通 的 查找 串 。 如 正则 表达 式 “testing” 中 没 
有 包含 任何 元 字符 ， 它 可 以 匹配 “testing” 和 “123testing” 等 字符 串 ， 但 是 不 能 匹配 “Testing”。 下 
面 详细 介绍 模式 匹配 的 使 用 。 

1. 元 字符 “^”、“$” 的 使 用 

首先 来 介绍 两 个 特别 的 元 字符 : “^” 和 “$”， 上 面 说 过 它们 是 分 别 用 来 匹配 字符 串 的 开始 和 结 
束 ， 以 下 分 别 举例 说 明 : 

"^The" 

匹配 以 The 开头 的 字符 串 。 

"of despair$" 

匹配 以 of despair 结尾 的 字符 串 。 

"^abc$" 

匹配 以 abc 开头 和 以 abc 结尾 的 字符 串 《〈 实 际 上 ， 只 有 abe 与 之 匹配 ) 。 

"notice" 

匹配 包含 notice 的 字符 串 。 

如 果 没 有 用 到 “^” 和 “$”《【 最 后 一 个 例子 ) ， 就 是 说 模式 〈 正 则 表达 式 ) 可 以 出 现在 被 检验 字 
符 串 的 任何 地 方 ， 因 为 没有 被 锁定 到 两 边 。 

2. 元 字符 “*”、“+”、“3” 的 使 用 

元 字符 “*”、“+” 和 “?” 用 来 表示 一 个 字符 可 以 出 现 的 次 数 或 者 顺序 。 这 3 个 字符 分 别 表 示 : 0 
次 或 者 多 次 ，1 次 或 者 多 次 ; 0 次 或 者 1 次 。 下 面 给 出 儿 个 例子 来 说 明 这 3 个 元 字符 是 如 何 匹配 字符 的 。 

nabi" 

匹配 字符 串 a 和 0 个 或 者 更 多 b 组 成 的 字符 串 。 如 “a”、“ab”、“abbb” 等 。 

"abe" 

和 上 面 一 样 ， 但 最 少 有 一 个 b。 如 “ab”、“abbb” 等 。 

"ab?" 

匹配 0 个 或 者 一 个 b。 只 有 两 种 可 能 “a” 和 “ab”。 

53. 综合 使 用 “hiw npe. emm, tam, eg 

下 面 把 以 上 两 种 模式 中 的 5 个 字符 综合 起 来 举 几 个 例子 。 

"a?b*$" 

匹配 以 一 个 或 者 0 个 a 再 加 上 一 个 以 上 的 b 结尾 的 字符 串 。 如 “b”、“ab”、“abb”、“abbb” 等 。 

"^a'b?a$" 

匹配 以 0 个 或 者 多 个 a 开头 再 加 上 0 个 或 者 1 个 b 再 以 a 结尾 的 字符 串 。 如 “a”、“aa”、“abaaa”、 


“aabaa” 等 。 
© 


M ea 


4. 元 字符 “{”、 "y" 的 使 用 
上 面 讲 了 “{”、“}” 分 别 是 数量 限定 符 开始 和 结束 的 标记 ， 所 以 也 可 以 在 大 括号 里 面 加 上 数字 
来 限制 字符 出 现 的 个 数 。 如 : 


"ab(2y 
匹配 一 个 a 后 面 跟 两 个 b〈 一 个 也 不 能 少 ) 。 如 “abb”。 

"ab. 

两 个 或 者 更 多 个 “b”《〈 即 最 少 跟 两 个 b) 。 如 “abb”、“abbbb” 等 。 
"aba," 


a 后面 跟 3 一 5 个 b ( 仅 有 3、4、5 个 3 种 情况 ) 。 如 “abbb”、“abbbb”、“abbbbb”。 
通过 上 面 的 例子 ， 读 者 能 够 发 现 只 能 使 用 “ {0,2}”， 而 不 能 使 用 “{,2}”。 同 样 ，“*”、 em 
和 “?” 分 别 和 以 下 3 个 范围 标注 是 一 样 的 ，“{0,}”、“{1,}” 和 “{0,1}”。 


5. 元 字符 “(”、“)” 的 使 用 

介绍 完 大 括号 ， 再 来 介绍 小 括号 。 

现在 把 一 定数 量 的 字符 放 到 小 括号 里 ， 如 : 

"a(bc)?" 

匹配 a 后 面 跟 0 个 或 者 1 "bc" . W "a" . "abc" (只 有 此 两 种 情况 ) 。 
"a(bo)(1,5)" 

匹配 a 后 面 跟 1 一 5 ^ “be” . Al] "abc" . "abcbc" . "abcbcbc" . "abcbcbcbc" ^5. 
6. 元 字符 “|” 的 使 用 

还 有 一 个 字符 “ | ”， 相 当 于 OR R) 操作 。 如 : 


"hi | hello" 
匹配 含有 “hi” 或 者 “hello” 的 字符 串 。 
"(b | cd)ef" 
匹配 含有 “bef” 或 者 “cdef” 的 字符 串 。 
"(a | bc" 


匹配 含有 这 样 0 到 多 个 〈 包 括 0 个 ) a 或 b， 后 面 跟 一 个 c 的 字符 串 。 
7. 元 字符 “.” 的 使 用 

下 面 介 绍 “.” 符 号 。 一 个 点 “.” 可 以 代表 所 有 的 单一 字符 ， 如 : 
"a.[0-9]" 

匹配 一 个 a 跟 一 个 字符 再 跟 一 个 数字 的 字符 串 。 

"^a.(3)$" 


[CN 
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匹配 以 a 开头 3 个 任意 字符 结尾 。 

8. 元 字符 “[”、“]” 的 使 用 

“[0” 中 括号 括 住 的 部 分 只 匹配 单一 字符 。 

"[ab]" 

匹配 单个 a 或 者 b (和 “a | b” 一 样 ) 。 

"adr 

匹配 “a” 到 “d” 的 单个 字符 G “a |b | c|d” 及 “[abcd]” 的 效果 一 样 ) 。 
wlazA-Z 

匹配 以 字母 开头 的 字符 串 。 

"[0-9]%" 

匹配 含有 形 如 x% 的 字符 串 。 

" [a-zA-Z0-9]$" 

匹配 以 逗号 再 加 一 个 数字 或 字母 结尾 的 字符 串 。 

9. 中 括号 内 的 元 字符 “^” 的 使 用 

具体 使 用 时 也 可 以 把 不 想 要 的 字符 列 在 中 括号 里 ， 只 需要 在 中 括号 里 面 使 用 “^” 作 为 开头 。 即 中 


括号 里 面 的 “^” 符 号 表示 多 辑 非 。 


"9%6[Aa-zA-Z]%" 
匹配 两 个 百 分 号 中 间 含 有 一 个 非 字 母 的 字符 串 。 如 “%1%”、“%5%” 等 。 


12.2 POSIX 扩展 的 正则 表达 式 函 数 


12.1 节 为 读者 介绍 了 PHP 中 的 匹配 模式 ， 但 是 光 有 模式 是 不 能 做 事情 的 ， 必 须 得 有 函数 与 之 一 起 


使 用 才能 起 作用 , 所 以 本 节 就 来 介绍 PHP 中 的 正则 表达 式 函 数 。 PHP. 支持 两 种 模式 的 正则 表达 式 函 数 ， 
即 PHP 中 有 两 类 正则 表达 式 函 数 。 一 类 是 比较 常用 的 POSIX (Portable Operating System Interface, AJ 
移植 操作 系统 接口 ) 扩展 的 正则 表达 式 函 数 ， 另 一 类 是 Perl 兼容 的 正则 表达 式 函 数 。 两 组 函数 功能 大 
同 小 异 ， 但 函数 名 称 及 使 用 方法 却 不 尽 相同 。 下 面 分 别 作 介绍 。 


12.2.1 ”替换 字符 串 


EB 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 12 章 \ 赫 换 字符 囊 -wmv 
string ereg replace(string pattern,string replacement, string string) 
该 函数 为 正则 表达 式 替 换 函 数 ， 此 函数 在 string 中 扫描 与 pattern 匹配 的 部 分 ， 并 将 其 替换 为 


replacement。 返 回 替换 后 的 字符 串 。 如 果 没 有 可 供 蔡 换 的 匹配 项 则 会 返回 原 字符 串 。 


© 
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【实例 12-1】 以 下 代码 演示 ereg_replace0 函 数 的 使 用 方法 。 


TE | 实例 12-1，ereg_replace() 函 数 的 使 用 方法 


源码 路 径 : 光盘 \ 源 文件 \12\12-1.php 


<head> 
<title>ereg_replace() 函 数 使 用 实例 1</title> 
</head> 
<body> 
<?php 
$string1-"abcacbcbaaab"; /定义 字符 串 变 量 
$string2=ereg_replace("a","b",$string1); // 对 字符 串 进行 替换 操作 
echo "string1 的 内 容 为 :"; 
echo $string1; /| 输出 原 字符 串 内 容 
echo "<p>"; 
echo "经 过 ereg replace 处 理 ( 将 a 替换 为 b) 过 的 内 容 为 : "; 
echo "<p>"; 
echo $string2; /| 输出 处 理 过 之 后 的 内 容 
?> 
</body> 
</html> 


在 PHP 运行 环境 中 执行 该 PHP 文件 ， 执 行 结果 如 图 12.1 所 示 。 


loo je 


ttpj//localhost/1z O ~ © || & ereg rep. 


| string1 的 内 容 为 ，abeacbcbaaab 
经 过 eree_repiace 处 理 at) 过 的 内 容 闪 ， 
bbctcbcbbbbb 


[ EET CNN 


图 12.1. ereg_replace() 函 数 使 用 实例 1 执行 结果 


上 面 的 实例 只 是 使 用 了 简单 的 查找 蔡 换 ， 并 没有 用 到 正则 表达 式 模式 。 只 是 通过 该 实例 先 来 了 解 
一 下 ereg_replace() 函 数 是 如 何 起 作用 的 。 通 过 上 例 及 执行 结果 可 见 ， 经 过 ereg_replace() 函 数 的 处 理 ， 
字符 串 $stringl 中 所 有 为 a 的 字符 全 被 蔡 换 成 b。 实 现 了 替换 字符 串 特定 内 容 的 目的 。 

【实例 12-2】 以 下 代码 演示 使 用 正则 表达 式 模式 进行 内 容 蔡 换 。 


re | 实例 12-2， 使 用 正则 表达 式 模式 进行 内 容 替 换 


源码 路 径 : 光盘 \ 源 文件 \12\12-2.php 


<head> 

<title>ereg_replace() 函 数 使 用 实例 2</title> 
</head> 

<body> 

<?php 


$0 rr 


07 S$string1-"abcdacdbcbadaab"; /定义 字符 串 变 量 
08 $string2=ereg_replace("[a-b]","c",$string1); // 对 字符 串 进行 替换 操作 
09 echo "string1 的 内 容 为 : "; 
10 echo $string1; // 输 出 原 字符 串 内 容 
11 echo "<p>"; 
12 echo "经 过 ereg replace 处 理 (将 a 和 b 蔡 换 为 c) 过 的 内 容 为 : "; 
13 echo "<p>"; 
14 echo $string2; /| 输出 处 理 过 之 后 的 内 容 
15 ?> 
16 </body> 
17 </html> 
在 PHP 运行 环境 下 执行 这 个 PHP 文件 ， 执 行 结果 如 图 122 Bras. 
[= me 


@ E mah O ~ © | B eres rep 


string] 的 内 容 为 ，abcdacdbcbadaab 
Kaja Hau FAAR 


cccdccdccccdccc 


LINE 


图 12.2 ereg_replace() 函 数 使 用 实例 2 执行 结果 
上 面 的 实例 用 到 了 正则 表达 式 模式 ， 实 现 的 功能 是 把 字符 串 $Sstringl 中 所 有 的 a fl 替换 成 c。 经 
过 这 样 的 处 理 ， 字 符 串 中 只 有 c 和 d 了 注意 观察 $sting1 内 容 与 实例 12-1 的 不 同 之 处 ) 。 
12.22 ”匹配 字符 串 


GI 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 12 章 \ 匹 配 字符 囊 ,wmv 
bool ereg(string pattern,string string[,array regs]) 


该 函数 对 string 字符 串 进 行 查 找 ， 如 果 在 string 中 找到 pattern 模式 的 匹配 ， 则 返回 True, An 
有 找到 匹配 或 出 错 则 返回 False。 


注意 : 此 函数 与 Perl 兼 容 正则 表达 式 语 法 的 preg_match() 函 数 具 有 相同 的 功能 。 通 常 使 用 preg_match() 函 


数 是 比 ereg() 函 数 更 快 的 方案 。 

【实例 12-3】 以 下 代码 演示 ereg0 函 数 实现 字符 的 匹配 操作 。 
K < 实例 12-3:ereg0 函 数 实现 字符 的 匹配 操作 
mm | 源码 路 径 : 光盘 源 文件 I2l23.php 0000000000000 s 
01 <html> 
02 <head> 
03 ”<title>ereg() 函 数 使 用 实例 1</title> 
04 </head> 
05 «body» 
06 <?php 
07 $string1-"abcde"; /定义 变量 $string1 


M aaa 


08 $string2-"bbcde"; /定义 变量 $string2 

09 echo "string1 的 内 容 为 :"; 

10 echo $string1; /| 输出 内 容 

11 echo "<p>"; 

12 echo "string2 的 内 容 为 : "; 

13 echo $string2; /| 输出 内 容 

14 echo "«p»"; 

15 function panduan($s) // 在 ereg() 函 数 的 基础 上 自 定 义 一 个 函数 
16 { 

17 if(ereg("a",$s)) echo "BE a"; /根据 ereg() 函 数 返 回 结果 输出 不 同 内 容 
18 else echo "不 包含 a"; 

19 } 

20 echo "string1 中 包含 小 写字 母 a R3? "; 

21 panduan($string1); // 调 用 自 定义 函数 进行 判断 

22 echo "<p>"; 

23 echo "string2 中 包含 小 写字 母 a 吗 ? "; 

24 panduan($string2); // 调 用 自 定义 函数 进行 判断 

25 7?» 

26 </body> 

27 «html» 


上 面 的 实例 中 ， 只 是 简单 地 判断 在 一 个 字符 串 中 有 没有 包含 另 一 个 字符 ， 其 中 并 没有 用 到 正则 表 
达 式 模式 。 在 PHP 运行 环境 中 执行 该 PHP 文件， 执行 结果 如 图 12.3 所 示 。 


sting] 的 内 容 为 ，abcae 
suing2 的 内 容 为 ，bbcde 

sting] 中 包含 小 号 字母 加 ? 包含 a 
minh & &/ | E Gat 1 不 包 言 a 


图 12.3 ”ereg() 函 数 使 用 实例 1 执行 结果 
从 以 上 实例 及 执行 结果 可 以 发 现 , 通过 在 ereg() 函 数 基础 上 构建 的 自 定义 函数 正确 地 输出 了 一 个 字 
符 串 中 是 否 含有 另 一 个 字符 OD. 
【实例 12-4】 以 下 代码 演示 使 用 正则 表达 式 模式 对 字符 串 进行 是 否 匹 配 的 判断 。 


re 实例 12-4: 使 用 正则 表达 式 模式 对 字符 串 进行 是 否 匹 配 的 判断 
源码 路 径 ， 光盘 \ 源 文件 \12\12-4.php 


02 <head> 

03 ”<title>ereg() 函 数 使 用 实例 2</title> 

04 </head> 

05 <body> 

06 <?php 

07 $string1-"abcde"; /定义 变量 $string1 
08 $string2-"ABCD"; /定义 变量 $string2 
09 echo "string1 的 内 容 为 : "; 

10 echo $string1; /| 输出 内 容 
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11 echo "<p>"; 

12 echo "string2 的 内 容 为 : "; 

13 echo $string2; /| 输出 内 容 

14 echo "<p>"; 

15 function panduan($s) /在 ereg() 函 数 的 基础 上 自 定义 一 个 函数 
16 { 

17 if(ereg("[a-z]",$s)) echo "包含 小 写字 母 "; /根据 ereg() 函 数 返 回 结果 输出 不 同 内 容 
18 else echo "不 包含 小 写字 母 "; 

19 H 

20 echo "string1 中 包含 小 写字 母 吗 ? "; 

21 panduan($string1); // 调 用 自 定义 函数 进行 判断 

22 echo "«p»"; 

23 echo "string2 中 包含 小 写字 母 吗 ? "; 

24 panduan($string2); // 调 用 自 定义 函数 进行 判断 

25 ?> 

26 </body> 

27 </html> 


在 PHP 运行 环境 中 执行 该 PHP 文件 ， 执 行 结果 如 图 12.4 所 示 。 


stringl 的 内 容 为 ，abcde 
string2 的 内 容 为 ，ABCD 
string1 中 包 合 小 号 字 号 吗 ? 包含 小 写字 母 
string2? 中 包 食 小 写字 号 吗 ? 不 包含 小 号 字母 


Aio ~ 


图 12.4 ereg() 函 数 使 用 实例 2 执行 结果 
此 次 自 定义 的 函数 在 使 用 ereg0) 函 数 时 ， 调 用 了 正则 表达 式 模式 ， 即 [az] (所 有 的 小 写字 母 ) 。 对 
两 个 字符 串 中 是 否 含有 小 写字 母 进行 判断 。 从 执行 结果 中 也 可 以 了 解 到 ， 由 于 $stringl 中 包含 了 小 写字 
母 ， 所 以 ereg() 函 数 返 回 True; 而 $string2 中 没有 包含 小 写字 母 (其 中 全 为 大 写字 母 ，，ereg() 函 数 返 回 
了 False。 通 过 该 实例 也 可 以 了 解 此 函数 是 如 何 起 作用 的 。 
12.2.3 ”替换 字符 串 (忽略 大 小 写 ) 


GER 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 12 章 \ 替 换 字 符 囊 ( 忽略 大 小 写 ) wmv 
string eregi replace(string pattern,string replacement,string string) 
该 函数 用 于 不 区 分 大 小 写 的 正则 表达 式 替 换 。 此 函数 与 ereg_replace0 函 数 有 一 样 的 功能 ， 除 了 在 


蔡 换 字母 字符 时 忽略 字母 的 大 小 写 。 


【实例 12-5】 以 下 代码 演示 eregi_replace() 与 ereg_repalce(O) 函 数 的 区 别 之 处 。 


区 | 实例 12-5: eregi replace() 5 ereg_repalce() 函 数 的 区 别 


源码 路 径 : 光盘 \ 源 文件 \12\12-5.php 


01 <html> 
02 <head> 


KA aaa 


03 ”<tile>eregi_replace() 函 数 使 用 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 $string1-"abcacbcbAAAb"; /定义 字符 串 变 量 


08 $string2=eregi_replace("a","b",$string1); // 对 字符 串 进行 替换 操作 


09 echo "string1 的 内 容 为 :"; 

10 echo $string1; /输出 原 字符 串 内 容 
11 echo "«p»"; 

12 echo "经 过 eregi replace 处 理 ( 将 a 蔡 换 为 b) 过 的 内 容 为 : "; 

13 echo "<p>"; 


14 echo $string2; // 输 出 处 理 过 之 后 的 内 容 


15 ?> 
16 </body> 
17 </html> 
在 PHP 运行 环境 下 执行 该 PHP 文件 ， 执 行 结果 如 图 12.5 所 示 。 


PII 


© htp//locahosti: © ~ © | E eregi repli 


strirg] 的 内 容 为 ，abcacbcbAAAb 
经 过 eregi_replac: 处 理 (Fatis b) 过 的 内 容 为， 
bbebebeobbbb: 


Rioo% v 


图 12.5 eregi_replace() 函 数 使 用 实例 执行 结果 


从 图 12.5 可 以 了 解 ， 由 于 忽略 了 字母 字符 的 大 小 写 ， 所 以 大 写字 母 A 也 被 蔡 换 成 了 小 写字 母 b。 


由 于 该 函数 与 ereg_replace() 函 数 功 能 大 致 相似 ， 所 以 不 再 多 作 介绍 。 
12.24 ”匹配 字符 串 〈 忽 略 大 小 写 ) 
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bool eregi(string pattern,string string[,array regs]) 


该 函数 用 于 不 区 分 大 小 写 的 正则 表达 式 匹 配 。 此 函数 与 ereg() 函 数 有 一 样 的 功能 ， 不 同 的 是 , 在 进 


行 正则 表达 式 的 匹配 字母 字符 时 也 忽略 字母 的 大 小 写 。 
【实例 12-6】 以 下 代码 演示 eregiO 函 数 的 使 用 方法 。 


区 实例 12-6: eregi0 函 数 的 使 用 方法 
源码 路 径 : 光盘 \ 源 文件 \12\12-6.php 


02 <head> 

03 ”<title>eregi() 函 数 使 用 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 $string1-"abcde"; /定义 变量 $string1 
08 $string2-"ABCD"; /定义 变量 $string2 


-—— 


09 echo "string1 的 内 容 为 :"; 

10 echo $string1; /| 输出 内 容 

11 echo "<p>"; 

12 echo "string2 的 内 容 为 : "; 

13 echo $string2; /| 输出 内 容 

14 echo "<p>"; 

15 function panduan($s) // 在 eregi() 函 数 的 基础 上 自 定义 一 个 函数 
16 

17 if(eregi("[a-z]",$s)) echo "包含 小 写字 母 "; /根据 eregi() 函 数 返回 结果 输出 不 同 内 容 
18 else echo "不 包含 小 写字 母 "; 

19 H 

20 echo "string1 中 包含 小 写字 母 吗 ? "; 

21 panduan(Sstring1 ); // 调 用 自 定义 函数 进行 判断 

22 echo "«p»"; 

23 echo "string2 中 包含 小 写字 母 吗 ? "; 

24 panduan(Sstring2); // 调 用 自 定义 函数 进行 判断 

25 7?» 

26 </body> 

27 «html» 


在 PHP 运行 环境 下 执行 该 PHP 文件 ， 执 行 结果 如 图 12.6 所 示 。 


"Tm 


ETSI 


localhost: O ~ (j| & 


string1 的 内 容 为 ，abcde 


string2 的 内 容 为 ，ABCD 


string1l 中 包含 小 写字 母 吗 ? 包含 小 写字 母 
string2 中 包含 小 写字 母 吗 ? 包含 小 写字 母 


Rioo% > 


图 12.6 eregi(O 函 数 使 用 实例 执行 结果 
因为 eregi0 函 数 在 进行 匹配 时 是 忽略 字母 字符 的 大 小 写 的 ， 所 以 会 将 所 有 字母 字符 蔡 换 。 这 也 提 


醒 了 用 户 ， 在 进行 大 小 写字 母 精确 匹配 时 应 该 使 用 
12.2.5 “分 割 字符 串 到 数组 


ereg() 函 数 而 不 能 使 用 eregiO0 函 数 。 


GRI 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 12 章 \ 分 割 字符 囊 到 数组 .wmv 


array split(string pattern,string string[,int limit]) 


该 函数 使 用 正则 表达 式 将 字符 串 分 割 到 数组 中 ， 执 行 成 功 后 返回 一 个 字符 串 数组 ， 数 组 的 每 个 元 


素 为 string 经 区 分 大 小 写 的 正则 表达 式 pattern 作为 边界 分 割 出 的 子 串 。 如 果 设 定 了 limit， 则 返 
最 多 包含 limit 个 单元 ， 最 后 一 个 单元 包含 了 string 中 剩余 的 所 有 部 分 。 如 果 出 错 ， 则 返 


组 


回 的 数 
回 False。 


注意 : 使 用 了 Per 兼容 正则 表达 式 语 法 的 preg_split() 函 数 通常 是 比 split() 函 数 更 快 的 替代 方案 。 


使 用 数组 操作 函数 中 的 explodeO 函 数 比 使 用 了 
浪费 。 


E 则 表达 式 更 快 ， 这 样 也 不 会 招致 正则 表达 式 引 擎 的 


网 络 编程 技术 详解 


【实例 12-7】 以 下 代码 演示 split() 函 数 是 如 何 把 字符 串 切 分 为 数组 的 。 


re 实例 12-7: split() 函 数 把 字符 串 切 分 为 数组 
源码 路 径 : 光盘 \ 源 文件 \12\12-7.php 


01 «html» 

02 <head> 

03 ”<title>split() 函 数 使 用 实例 1</title> 

04 </head> 

05 <body> 

06 <?php 

07 $string1-"ab:cd:efgh:i"; /定义 变量 $string1 
08 echo "string1 的 内 容 为 :"; 

09 echo $string1; /| 输出 内 容 

10 echo "<p>"; 

11 echo "经 过 split 处 理 过 之 后 的 数组 内 容 为 :"; 

12 echo "<p>"; 

13 $temp=split(":",$string1); // 对 字符 串 进行 split 处 理 
14 for($i=0;$i<count($temp);$i++) // 通 过 循环 输出 数组 内 容 
15 ( 

16 echo "temp|".$i."JA: "; 

17 echo $temp[$i]; 

18 echo", "; 

19 $ 

20 7> 

21 </body> 

22 </html> 


在 PHP 运行 环境 中 执行 该 PHP 文件 ， 执 行 结果 如 图 12.7 所 示 。 


Grm 
[€] E wei ecsbeni: O ~ © | S siccae mn «| 
string] 的 内 容 为 ，ab:ed-efehi 

经 过 split 处 理 过 之 后 的 数组 内 容 为 ， 

temp[O]9. ab. temp[Ij. cd, temp, efh. temp[]9s i 


LIE 


图 12.7. splitO) 函 数 使 用 实例 1 执行 结果 


从 图 12.7 可 以 了 解 到 ， 经 过 split() 函 数 的 处 理 ， 把 原来 的 字符 串 变 量 $stringl 按照 “:” 分 割 成 了 数组 。 

【实例 12-8】 以 下 代码 演示 以 正则 表达 式 模式 作为 标准 时 ，split(0) 函 数 是 如 何 起 作用 的 。 

区 Dnm WA WAA AA AAA AAA AA AAA 
源码 路 径 : 光盘 \ 源 文件 \12\12-8.php 


<head> 

<title>split() 函 数 使 用 实例 2</title> 
</head> 

<body> 

<?php 


01 
02 
03 
04 
05 
06 
e. 


ans uzuni 0000 


07 $string1-"ab123cd2efgh890i"; /定义 变量 $string1 
08 echo "string1 HAFA: "; 
09 echo $string1; // 输 出 内 容 
10 echo "<p>"; 
11 echo "经 过 split 处 理 过 之 后 的 数组 内 容 为 : "S 
12 echo "<p>"; 
13 S$temp-split("[0-9]*",$string1); // 对 字符 串 进 行 split 处 理 
14 for($i=0;$i<count($temp);$i++) // 通 过 循环 输出 数组 内 容 
15 { 
16 echo "temp[".Si."]Z9: "; 
17 echo Stemp[Si]; 
18 echo", * 
19 H 
20 ?> 
21 </body> 
22 </html> 
在 PHP 运行 环境 下 执行 该 PHP 文件 ， 执 行 结果 如 图 12.8 所 示 。 
r IEEE] 


string1 的 内 容 汐 ，ab123cd2efghS90i 
经 过 split 处 理 过 之 后 的 数组 内 容 为 : 
temp[O5. ab, temp[l]9. cd，temgp[2] 为 ，efgh，temp[3] 为 i 


100€ ~ 
图 12.8 splitO) 函 数 使 用 实例 2 执行 结果 


该 实例 中 对 字符 串 分 割 时 使 用 的 分 割 标准 是 一 个 正则 表达 式 模 式 “[0-9]+”， 即 1 到 多 个 数字 ， 也 
就 是 用 一 到 多 个 数字 作为 分 割 的 标准 。 


12.26 分割 字 符 串 到 数组 (忽略 大 小 写 ) 


(OU 知识 点 讲解 :光盘 \ 视 频 讲 解 \ 第 12 章 \ 分 割 字符 囊 到 数组 (忽略 大 小 写 ) wmv 
array spliti(string pattern,string stringl,int limit]) 
该 函数 实现 功能 与 split() 函 数 完全 一 样 ， 只 是 在 对 字符 串 进行 分 割 时 忽略 字母 字符 的 大 小 写 。 
由 于 此 函数 与 split0 函 数 功 能 相似 , 唯一 的 不 同 就 是 在 分 割 时 忽略 了 字母 字符 的 大 小 写 。 所 以 下 面 
就 只 通过 一 个 简单 的 实例 来 说 明 该 函数 是 如 何 使 用 的 。 
【实例 12-9】 以 下 代码 演示 splitiO) 函 数 的 使 用 。 


区 实例 12-9. spliti0 函 数 的 使 用 
源码 路 径 光盘 \ 源 文件 \12\12-9.php 


02 <head> 
03 ”<title>spliti() 函 数 使 用 实例 </title> 
04 </head> 
05 <body> 


KA aaa 


06 <?php 

07 Sstring1-"abzcdZefghzi"; /定义 变量 $string1 

08 echo "string1 的 内 容 为 :"; 

09 echo $string1; // 输 出 内 容 

10 echo "<p>"; 

11 echo "经 过 spliti 处 理 过 之 后 的 数组 内 容 为 : "; 

12 echo "<p>"; 

13 $temp-spliti("z",$string1); // 对 字符 串 进行 split 处 理 
14 for($i=0;$i<count($temp);$i++) // 通 过 循环 输出 数组 内 容 
15 { 

16 echo "temp|".$i."JA: "; 

17 echo $temp[$i]; 

18 echo", "; 

19 H 

20 ?> 

21 </body> 

22 </html> 

在 PHP 运行 环境 中 执行 该 PHP 文件， 执行 结果 如 图 12.9 所 示 。 


sj 
[€] E ploclhesy1: P ~ Ò | S pinanarsn 
string1 的 内 容 为 ，abzcdZeighz 

经 过 spliti 处 理 过 之 后 的 数组 内 容 为 ， 

temp[0]9: ab, temp[:]9. cé, temp[2]J). efgh, temp]. i. 


R100% ~ 


图 12.9. splitiO 函 数 使 用 实例 执行 结果 
在 以 上 实例 中 ， 使 用 小 写字 母 z 来 作为 分 割 标 准 ， 但 是 字符 串 变量 $string 中 既 含 有 小 写字 母 z X 
有 大 写字 母 Z。 如 果 是 使 用 split0 函 数 进行 分 割 , 会 只 严格 地 使 用 小 写字 母 , 返回 的 数组 只 有 3 个 元 素 。 
由 于 spliti0) 函 数 是 忽略 字母 字符 的 ， 所 以 把 大 写字 母 也 作为 分 割 标 准 ， 这 样 返回 的 数组 就 有 4 个 元 素 。 


12.2.7 ”返回 包含 指定 字符 的 正则 表达 式 


EH 知识 点 讲解 光盘 \ 视 频 讲解 \ 第 12 章 \ 返 回 包含 指定 字符 的 正则 表达 式 .wmv 

string sql_regcase(string string) 

该 函数 用 于 产生 不 区 分 大 小 写 匹配 的 正则 表达 式 。 此 函数 返回 与 string 相 匹 配 的 正则 表达 式 ， 不 
论 大 小 写字 母 。 返 回 的 表达 式 是 将 string 中 的 每 个 字母 字符 转换 为 方 括号 表达 式 ， 该 方 括号 表达 式 包 
含 了 该 字母 的 大 小 写 两 种 形式 。 其 他 非 字 母 字 符 保留 不 变 。 

【实例 12-10】 以 下 代码 演示 sql_regcase0 函 数 的 使 用 。 


re 实例 12-10: sql_regcase(0) 函 数 的 使 用 
源码 路 径 光盘 \ 源 文件 \12\12-10.php 


01 <html> 
02 <head> 
03 ”<title>sql_regcase() 函 数 使 用 实例 </title> 


[CN 


1$ 12€ PHP 中 正则 表达 式 E 


04 </head> 

05 <body> 

06 <?php 

07 $string1-"ab-zcdlZefg?hzi"; /定义 变量 $string1 
08 echo "string1 的 内 容 为 : "; 

09 echo $string1; /和 输出 内 容 

10 echo "<p>"; 

11 echo "经 过 sgl regcase 处 理 过 之 后 的 内 容 为 :"; 

12 echo "<p>"; 

13 $string2-sql regcase($string1); // 对 字符 串 进行 sql_regcase 处 理 
14 echo $string2; /输出 处 理 过 的 结果 
15 ? 

16 </body> 

17 «html» 


在 PHP 运行 环境 下 执行 该 PHP 文件 ， 执 行 结果 如 图 12.10 所 示 。 


Baaz | B re 
siringi MABA. ab-zcéZefa?hzi 
经 过 sql_regcasc 处 理 过 之 后 的 内 容 为 ， 
[Aa][BbHZz]ECcEDa) LZ JEe EF (Gg HHZ] 
[t7 v 


图 12.10. sql_regcase() 函 数 使 用 实例 执行 结果 


从 执行 结果 可 以 了 解 到 , 经 过 sql_regcase0 函 数 处 理 ， 原 来 的 每 个 字母 字符 都 转换 成 了 方 括 号 表达 
式 ， 该 方 括号 表达 式 包 含 了 该 字母 的 大 小 写 两 种 形式 。 该 函数 使 用 的 场合 就 是 对 包含 字母 规则 的 正则 
表达 式 模式 进行 处 理 ， 使 原本 只 支持 大 写 或 者 小 写 的 正则 表达 式 模式 〈 字 串 ) 转变 成 不 区 分 大 小 写 的 
正则 表达 式 模式 。 


12.3 Perl 兼容 的 正则 表达 式 函 数 


PHP 有 两 组 正则 表达 式 函 数 。 在 12.2 节 介 绍 POSIX 扩展 的 正则 表达 式 函 数 的 时 候 就 曾 提 到 有 儿 个 
可 以 相互 替代 的 函数 。 通 常情 况 下 ， 二 者 在 某 些 功能 上 具有 相似 性 ， 可 以 替代 。 


12.3.1 Perl 兼容 正则 表达 式 的 使 用 规范 


GR 知识 点 讲解 : 光盘 \ 视 频 讲 解 \ 第 12 章 \Perl 兼容 正则 表达 式 的 使 用 规范 .wmv 

使 用 Perl 兼容 正则 表达 式 函数 的 表达 式 应 被 包含 在 定 界 符 中 ， 如 斜 线 (/) 。 任 何不 是 字母 、 数 字 
或 反 斜 线 CO 的 字符 都 可 以 作为 定 界 符 。 如 果 作 为 定 界 符 的 字符 必须 被 用 在 表达 式 本 身 中 ， 则 需要 用 
FRERE. É PHP 4.0.4 起 ， 也 可 以 使 用 Perl 风格 的 0)，f}， 口 和 <> 匹 配 定 界 符 。 结 束 定 界 符 后 可 以 
跟 上 不 同 的 修正 符 以 影响 匹配 方式 。 

下 面 列 出 了 当前 在 PCRE 中 可 能 使 用 的 修正 符 。 括 号 中 是 这 些 修 正 符 的 内 部 PCRE 名 。 修 正 符 中 
的 空格 和 换行 被 忽略 ， 其 他 字符 会 导致 错误 。 


1. i(PCRE CASELESS) 

如 果 设 定 此 修正 符 ， 模 式 中 的 字符 将 同时 匹配 大 小 写字 母 。 

2. m (PCRE MULTILINE) 

默认 情况 下 , PCRE 将 目标 字符 串 作 为 单一 的 一 “ 行 ”字符 (甚至 其 中 包含 换行 符 也 是 如 此 ) 。“ 行 
起 始 ” 元 字符 〈^) 仅仅 匹配 字符 串 的 起 始 ，“ 行 结束 ”元 字符 〈$) 仅仅 匹配 字符 串 的 结束 ， 或 者 最 
后 一 个 字符 是 换行 符 时 其 前 面 〈 除 非 设 定 了 D 修正 符 ) 的 字符 串 。 

当 设 定 了 此 修正 符 ，“ 行 起 始 ” 和 “ 行 结束 ”除了 匹配 整个 字符 串 开 头 和 结束 外 ， 还 分 别 匹 配 其 
中 的 换行 符 之 后 和 之 前 的 内 容 。 这 和 Perl 的 /m 修正 符 是 等 效 的 。 如 果 目 标 字 符 串 中 没有 “\ ”字符 或 
者 模式 中 没有 “^” 或 “$”， 则 设 定 此 修正 符 没有 任何 效果 。 

3. s (PCRE_DOTALL) 

如 果 设 定 了 此 修正 符 ， 模 式 中 的 圆 点 元 字符 〈.) 匹配 所 有 的 字符 ,包括 换行 符 。 没 有 此 设 定 的 话 ， 
则 不 包括 换行 符 。 这 和 Perl 的 “/s” 修 正 符 是 等 效 的 。 排 除 字符 类 如 “[^a]” 总 是 匹配 换行 符 的 ， 无 论 
是 否 设 定 了 此 修正 符 。 

4. x (PCRE_EXTENDED) 

如 果 设 定 了 此 修正 符 ， 模 式 中 的 空白 字符 除了 被 转 义 的 或 在 字符 类 中 的 以 外 完全 被 忽略 ， 在 未 转 
义 的 字符 类 之 外 的 “# ”以 及 下 一 个 换行 符 之 间 的 所 有 字符 ， 包 括 两 头 ， 也 都 被 忽略 。 这 和 Perl 的 “/x” 
修正 符 是 等 效 的 ， 使 得 可 以 在 复杂 的 模式 中 加 入 注释 。 然 而 注意 ， 这 仅 适 用 于 数据 字符 。 空 白字 符 可 
能 永远 不 会 出 现在 模式 中 的 特殊 字符 序列 ， 如 引入 条 件 子 模 式 的 序列 〈?) 中 间 。 

5.e 

如 果 设 定 了 此 修正 符 , preg_replace() 函 数 在 蔡 换 字符 串 中 对 逆向 引用 作 正 常 的 替换 , 将 其 作为 PHP 
代码 求 值 ， 并 用 其 结果 来 替换 所 搜索 的 字符 串 。 只 有 preg_replace() 函 数 使 用 此 修正 符 ， 其 他 PCRE PR 
数 将 忽略 之 。 


注意 : 此 修正 符 在 PHP 3.0 中 不 可 用 。 
6. A CPCRE ANCHORED) 


如 果 设 定 了 此 修正 符 ， 模 式 被 强制 为 anchored， 即 强制 仅 从 目标 字符 串 的 开头 开始 匹配 。 此 效果 
也 可 以 通过 适当 的 模式 本 身 来 实现 〈 在 Perl 中 实现 的 唯一 方法 ) 。 

7. D (PCRE_DOLLAR ENDONLY) 

如 果 设 定 了 此 修正 符 ， 模 式 中 的 美元 元 字符 仅 匹 配 目标 字符 串 的 结尾 。 没 有 此 选项 时 ， 如 果 最 后 
一 个 字符 是 换行 符 的 话 ， 美 元 符号 也 会 匹配 此 字符 之 前 《但 不 会 匹配 任何 其 他 换行 符 之 前 ) 。 如 果 设 
定 了 m 修正 符 则 忽略 此 选项 。Perl 中 没有 与 其 等 价 的 修正 符 。 


8. S 


当 一 个 模式 将 被 使 用 若干 次 时 ， 为 加 速 匹配 就 先 对 其 进行 分 析 。 如 果 设 定 了 此 修正 符 ， 则 会 进行 
额外 的 分 析 。 目 前 ， 分 析 一 个 模式 仅 对 没有 单一 固定 起 始 字符 的 non-anchored 模式 有 用 。 


e. 
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9. U (PCRE_UNGREEDY) 

此 修正 符 反 转 了 匹配 数量 的 值 使 其 不 是 默认 的 重复 而 变 成 在 后 面 跟 上 “?” 才 变 得 重复 。 这 和 Perl 不 
兼容 。 也 可 以 通过 在 模式 之 中 设 定 QUO 修正 符 或 者 在 数量 符 之 后 跟 一 个 问号 (如 .*?) 来 启用 此 选项 。 

10. X (PCRE EXTRA) 

此 修正 符 启 用 了 一 个 PCRE 中 与 Perl 不 兼容 的 额外 功能 。 模 式 中 的 任何 反 斜 线 后 面 跟 上 一 个 没有 
特殊 意义 的 字母 将 导致 一 个 错误 ， 从 而 保留 此 组 合 以 备 将 来 扩充 。 默 认 情 况 下 ， 和 Perl 一 样 ， 一 个 反 
和 斜 线 后 面 跟 一 个 没有 特殊 意义 的 字母 被 当成 该 字母 本 身 。 当 前 没有 其 他 特性 受 此 修正 符 控制 。 

11. u (PCRE_UTF8) 

此 修正 符 启 用 了 一 个 PCRE 中 与 Perl 不 兼容 的 额外 功能 。 模 式 字符 串 被 当成 UTF-8。 本 修正 符 在 
UNIX 下 自 PHP 4.1.0 起 可 用 , 在 Win32 下 自 PHP 4.2.3 起 可 用 。 自 PHP 4.3.5 起 开始 检查 模式 的 UTF-8 
合法 性 。 


12.3.2 ”返回 匹配 数组 


名 知识 点 讲解 ， 光盘 \ 视 频 讲 解 \ 第 12 章 \ 返 回 匹配 数组 .wmv 

array preg_grep(string pattern,array input) 

该 函数 返回 与 模式 匹配 的 数组 元 素 。 返 回 的 数组 包括 了 input 数组 中 与 给 定 的 pattern 模式 相 匹配 
的 元 素 。 自 PHP 4.0.4 起 ，preg_grep() 函 数 返 回 的 结果 使 用 从 输入 数组 的 键 名 进行 索引 。 如 果 不 希望 这 
样 的 结果 ， 用 array_values0) 函 数 对 preg_grep(O) 函 数 返回 的 结果 重新 索引 。 

【实例 12-11】 以 下 代码 演示 preg_grep0 函 数 如 何 从 数组 中 提取 出 适合 的 模式 匹配 。 


01 <html> 

02 <head> 

03 ”<title>preg_grep() 函 数 使 用 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 S$temp[0]-"abc"; /定义 数组 元 素 
08 S$temp[1]=123; 

09 $temp[2]="us."; 

10 $temp[3]=5; 

14 S$temp[4]=58; 

12 S$temp[5]="CS"; 

13 echo "数组 temp 的 内 容 为 :"; 

14 echo "<P>"; 

15 for($i=0; $i<count($temp);$i++) // 通 过 循环 输出 数组 内 容 
16 

17 echo $temp[Si]; 

18 echo", "; 
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19 ) 

20 echo "<p>"; 

21 echo "经 过 preg_grep() 处 理 过 之 后 的 新 数组 为 : "; 

22 Stemp2-preg grep("/^(id)d*/" $temp); // 使 用 preg grep 进行 处 理 
23 // 上 式 的 正则 表达 式 模式 中 “//” 为 定 界 符 ， 其 内 容 为 所 有 整数 元 素 

24 echo "<P>"; 

25 print r(Stemp2); // 通 过 循环 输出 新 数组 内 容 
26 ?> 

27 </body> 

28 </html> 


在 PHP 运行 环境 下 执行 该 PHP 文件 ， 执 行 结果 如 图 12.11 所 示 。 
[eco ncn 
cahosy/12 D = Ols 


Oo- 


数组 temp 的 大 容 为: 


abc, 123, us, 5, 58, CS, 
| 经 过 preg grepO 处 理 过 之 五 的 新 数组 为 ， 


Array [1] 2» 123 [3] 5 [4] 9 58) 


Rico% v 


图 12.11 preg_grep() 函 数 使 用 实例 执行 结果 


从 图 12.11 可 以 发 现 ， 经 过 preg_grep() 函 数 的 处 理 ， 提 取出 了 匹配 pattern 正则 表达 式 的 元 素 ， 组 
成 了 一 个 新 的 数组 。 然 而 新 数组 所 使 用 的 键 名 ， 依 然 是 原来 数组 的 键 名 。 


12.3.3 ”全 局 表达 式 匹配 


YA 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 12 章 \ 全 局 表达 式 匹配 .wmv 

int preg match all(string pattern,string subject,array matches[,intflags]) 

该 函数 进行 全 局 正则 表达 式 匹 配 。 在 subject 中 搜索 所 有 与 pattern 给 出 的 正则 表达 式 匹配 的 内 容 并 
将 结果 以 flags 指定 的 顺序 放 到 matches 中 。 搜 索 到 第 一 个 匹配 项 之 后 ， 接 下 来 的 搜索 从 上 一 个 匹配 项 
末尾 开始 。 函 数 返 回 整 个 模式 匹配 的 次 数 〈 可 能 为 零 ) ， 如 果 出 错 返 回 False。 

flags 可 以 是 下 列 标记 的 组 合 (注意 把 PREG. PATTERN ORDER 和 PREG SET ORDER 合 起 来 用 
没有 意义 ) : 

PREG PATTERN ORDER: 对 结果 排序 使 Smatches[0] 为 全 部 模式 匹配 的 数组 ，$matches[1] 为 

第 一 个 括号 中 的 子 模式 所 匹配 的 字符 串 组 成 的 数组 ， 以 此 类 推 。 
【实例 12-12】 以 下 代码 演示 preg_match_all0) 函 数 是 如 何 使 用 PREG_PATTERN_ORDER 参数 并 

对 结果 进行 排序 的 。 

区 SN | 实例 12-12: preg_match_all0) 函 数 如 何 使 用 PREG PATTERN ORDER 参数 并 对 结果 进行 排序 

源码 路 径 光盘 \ 源 文件 \12\12-12.php 


02 <head> 
03 ”<title>preg_match_all() 函 数 使 用 实例 1</title> 
04 </head> 
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05 <body> 

06 <?php 

07 $string-"«b»example: «/b» «div align-left»this is a test«/div»"; /定义 字符 串 

08 $patternz"|«[^»]4»(.*) «/[^»] *»|U"; // 定 义 正则 表达 式 模式 
09 preg_match_all($pattern,$string,$out,PREG_PATTERN_ORDER); /进行 preg_mathc_all 处 理 
10 echo Sout[O][0]; 

11 echo", "; 

12 echo $out[0][1]; 

13 echo "<p>"; 

14 echo S$out[1][0]; 

15 echo", "; 

16 echo S$out[1][1]; 

(rm 

18 </body> 

19 </html> 

在 PHP 运行 环境 下 执行 该 PHP 文件 ， 执 行 结果 如 图 12.12 所 示 。 


[€] rm localhost/12 £ 


example: » 

this is atest 

example., this is a test 
R100% - 


图 12.12 preg_match_all() 函 数 使 用 实例 1 执行 结果 

先 来 分 析 $pattem 正则 表达 式 模式 所 表示 的 含义 。 

$pattern="|<[^>]+>(.*)</[^>]+>]U"; 

其 中 的 “|”、“|” 为 定 界 符 ， 里 面 的 内 容 表示 什么 含义 呢 ? 

第 一 个 “<” 表 示 以 小 于 号 开头 的 内 容 ， 后 面 跟 1 个 到 多 个 不 为 “>” 的 字符 加 上 “> ”结尾 的 内 容 。 
子 模式 中 的 “.*” 表 示 0 到 多 个 任意 字符 。 再 加 上 以 “<” 开 头 的 内 容 后 面 跟 1 个 到 多 个 不 为 “>” 指 
字符 加 上 “>” 符 号 。 模 式 修订 符 “U?” 的 含义 是 : 反 转 了 匹配 数量 的 值 使 其 不 是 默认 的 重复 。 

从 图 12.12 可 以 发 现 ， 经 过 加 上 PREG_PATTERN_ORDER 参数 的 preg_match_all() 函 数 的 处 理 正 
确 地 返回 了 数组 。 

PREG SET ORDER: 对 结果 排序 使 Smatches[0] 为 第 一 组 匹配 项 的 数组 ，$matches[1] 为 第 二 组 
匹配 项 的 数组 ， 以 此 类 推 。 

【实例 12-13】 以 下 代码 演示 preg_match_all0 函 数 如 何 使 用 PREG_SET_ ORDER 对 字符 串 进 行 提 
取 及 排序 的 。 


re 实例 12-13: preg_match_all0 函 数 如 何 使 用 PREG_SET_ORDER 对 字符 串 进行 提取 及 排序 
源码 路 径 : 光盘 \ 源 文件 \12\12-13.php 


02 <head> 

03 ”<tile>preg_match_all() 函 数 使 用 实例 2</title> 
04 </head> 

05 <body> 


06 <?php 


07 $string-"«b»example: </b><div align-left»this is a test«/div»"; /定义 字符 串 

08 $pattern="|<[^>]+>(.*)</[^>]+>|U"; /定义 正则 表达 式 模式 
09 preg match all($pattern,$string,$outePREG SET ORDER); /| 进行 preg match all 处 理 
10 echo Sout[O][0]; 

11 echo", "; 

12 echo $out[ol[1]; 

13 echo "«p»"; 

14 echo S$out[1][0]; 

15 echo", "; 

16 echo S$out[1][1]; 

aU es 

18 </body> 

19 </html> 


在 PHP 运行 环境 下 执行 该 PHP 文件 ， 执 行 结果 如 图 12.13 Pros. 


example, example 


this is a test 
» this isa test 


Row ~ 


图 12.13 preg_match_all() 函 数 使 用 实例 2 执行 结果 
从 实例 及 图 12.13 的 执行 结果 可 以 了 解 到 ， 经 过 加 上 PREG SET ORDER 参数 的 preg match all() 
函数 的 处 理 使 得 $8out[0] 为 第 一 组 匹配 的 数组 ，$out[1] 为 第 二 组 匹配 的 数组 。 从 中 也 能 了 解 使 用 此 参数 
与 PREG_PATTERN_ORDER 参数 的 区 别 。 


12.8.4 正则 表达 式 匹配 


EB 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 12 章 \ 正 则 表达 式 匹配 .wmv 
int preg match(string pattern,string subject[,array matches [,int flags]]) 
该 函数 进行 正则 表达 式 匹配 。 在 subject 字符 串 中 , 搜索 与 pattern 给 出 的 正则 表达 式 相 匹配 的 内 容 。 
如 果 提 供 了 matches， 则 其 会 被 搜索 的 结果 所 填充 。$matches[0] 将 包含 与 整个 模式 匹配 的 文本 ， 
$matches[1] 将 包含 与 第 一 个 捕获 的 括号 中 的 子 模式 所 匹配 的 文本 ， 以 此 类 推 。 
【实例 12-14】 以 下 代码 演示 preg_match0 函 数 是 如 何 实现 对 所 给 的 字符 串 用 正则 表达 式 模式 进行 
匹配 的 。 


区 实例 12-14: preg_match() 函 数 如 何 实现 对 所 给 的 字符 串 用 正则 表达 式 模式 进行 匹配 
源码 路 径 : 光盘 \ 源 文件 \12\12-14.php 

01 <html> 

02 <head> 

03 ”<title>preg_match() 函 数 使 用 实例 </title> 

04 </head> 

05 <body> 
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06 <?php 

07 $string-"http://www.sohu.com"; /定义 字符 串 

08 $pattern-"/^(http:VV)?([^V]* i"; /定义 正则 表达 式 模式 
09 preg match($pattern,$string,$matchs); /进行 preg match 处 理 
10 echo "string 的 内 容 为 : "; 

11 echo $string; /输出 字符 串 变 量 内 容 
12 echo "<p>"; 

13 echo "经 过 preg match 函数 处 理 过 得 出 的 主机 名 为 : "S 

14 echo $matchs[2]; /输出 取得 数组 的 第 三 个 元 素 
15 ?> 

16 </body> 

17 </html> 


以 上 正则 表达 式 模式 实现 了 从 一 个 网 址 中 取得 主机 名 。 如 果 执 行 无 误 ， 将 会 输出 www.sohu.com。 
在 PHP 运行 环境 下 执行 该 PHP 文件 ， 执 行 结果 如 图 12.14 所 示 。 


感 htpWaaheanip = 四 | pn 


string 的 内 容 为 ， http:/www.sohu com 
经 过 preg match 函 数 处 理 过 得 出 的 主机 名 为 
" 


www.sohu.com 


Aix ~ 
图 12.14 ”preg_match() 函 数 使 用 实例 执行 结果 


从 图 12.14 所 输出 的 执行 结果 中 知道 ， 经 过 preg_match0O) 函 数 的 处 理 〈 即 使 用 正则 表达 式 模式 从 一 
个 网 址 中 取得 主机 名 ) 正确 得 出 了 相 匹 配 的 结果 。 


12.3.5” 转 义 正则 表达 式 字符 


(UE 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 12 章 \ 转 义 正 则 表达 式 字符 .wmv 

string preg_quote (string str[,string delimiter]) 

该 函数 以 str 为 参数 并 给 其 中 每 个 属于 正则 表达 式 语 法 的 字符 前 面 加 上 一 个 反 斜 线 。 如 果 需 要 以 动 
态 生成 的 字符 串 作 为 模式 去 匹配 ， 则 可 以 用 此 函数 转 义 其 中 可 能 包含 的 特殊 字符 。 

如 果 提 供 了 可 选 参数 delimiter， 该 字符 也 将 被 转 义 。 可 以 用 来 转 义 PCRE 函数 所 需要 的 定 界 符 ， 
最 常用 的 定 界 符 是 斜 线 “/”。 正 则 表达 式 的 特殊 字符 包括 Ut. NIV m tm 9n Ih, 
aan «ph. «gh. enu yr. «ou «yr. «am. «qno «ch «yn. «m, 


【实例 12-15】 以 下 代码 演示 preg_quote(O) 函 数 是 如 何 使 正则 表达 式 字符 实现 转 义 的 。 


区 实例 12-15: preg_quote() 函 数 如 何 使 正则 表达 式 字符 实现 转 义 
源码 路 径 光盘 \ 源 文件 \12\12-15.php 


02 <head> 

03 ”<title>preg_quote() 函 数 使 用 实例 1</title> 
04 </head> 

05 <body> 

06 <?php 


KA PHP Ra 


07 $pattern-"$40 for a g3/400"; /定义 正则 表达 式 模 式 字符 串 
08 S$out-preg quote($pattern,"/"); /| 进行 preg mathc. all 处 理 
09 echo "pattem 的 内 容 为 : "; 
10 echo $pattern; // 输 出 字符 串 变量 内 容 
11 echo "<p>"; 
12 echo "经 过 preg quote 函数 处 理 过 的 结果 为 : "S 
13 echo $out; // 输 出 处 理 后 的 结果 
14 ?> 
15 </body> 
16 </html> 
在 PHP 运行 环境 中 执行 该 PHP 文件 ， 执 行 结果 如 图 12.15 所 示 。 
lesu 


[c] B hupu O - È || & preg quoten£ 


pattem 的 内 容 为 ，S40fora g3/400 
经 过 preg_quote 函 效 处理 过 的 结果 为 $10 fora g3V400 


R100% v 
Æ 12.15 ”preg_quote() 函 数 使 用 实例 1 执行 结果 


【实例 12-16】 以 下 代码 演示 preg_quote0 函 数 与 preg_replace() 函 数 配合 使 用 给 某 个 单词 加 上 和 斜 线 
标记 。 


01 <html> 

02 <head> 

03 ”<title>preg_quote() 函 数 使 用 实例 2</title> 

04 </head> 

05 «body» 

06 <?php 

07 $string-"This book is *very* difficult to find."; /定义 字符 串 

08 S$wordz""very*"; // 定 义 子 字符 串 

09 $out=preg_quote($string,"/"); /进行 preg_mathc_all 处 理 
10 echo "out 的 内 容 为 :"; 

11 echo $out; // 输 出 字符 串 变量 内 容 
12 $stringout=preg_replace ("/".preg_quote($word)."/","<i>".$word."</i>",$string); 
13 echo "<p>"; 

14 echo "经 过 preg_replace 函数 处 理 过 的 结果 为 : "; 

15 echo $stringout; // 输 出 处 理 后 的 结果 
16 ?» 

17 </body> 

18 </html> 


在 PHP 运行 环境 中 执行 该 PHP 文件 ， 执 行 结果 如 图 12.16 Pros. 
通过 这 两 个 实例 的 学 习 ， 相 信 读 者 对 于 preg_quote() 函 数 的 使 用 都 有 了 一 个 比较 清晰 的 认识 。 
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gna uu 000 


Epreg quoe RUHRI. This book is “very” difficult to nd. 


ux» - | 


图 12.16 ”preg_quote() 函 数 使 用 实例 2 执行 结果 


12.3.6 ”用 回调 函数 实现 正则 表达 式 的 搜索 与 替换 


EH 知识 点 讲解 :光盘 \ 视 频 讲 解 \ 第 12 章 \ 用 回调 函 教 实现 正则 表达 式 的 搜索 与 替换 .wmv 
mixed preg replace callback(mixed pattern,callback callback,mixed subject[,int limit]) 
该 函数 执行 正则 表达 式 的 搜索 和 蔡 换 。 该 函数 的 功能 几乎 和 preg_replace() 函 数 一 样 。 除 了 不 是 提 
供 一 个 replacement 参数 ,而 是 指定 一 个 callback() 函 数 。 该 函数 将 以 目标 字符 串 中 的 匹配 数组 作为 输入 
参数 ， 并 返回 用 于 蔡 换 的 字符 串 。 
【实例 12-17] 以 下 代码 演示 preg_repalce_callback() 函 数 是 如 何 使 用 回调 函数 执行 正则 表达 式 的 搜 


索 与 替换 的 。 


。 8:81 12-17. preg_repalce_callback() 函 数 如 何 使 用 回调 函数 执行 正则 表达 式 的 搜索 与 替换 
源码 路 径 光盘 \ 源 文件 \12\12-17.php 


01 <html> 

02 <head> 

03 ”<tile>preg_replace_callback() 函 数 使 用 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 $text-" IR A 355: 04/01/2013"; 

08 $text.=" 上 一 个 圣诞 节 平安 夜 是 : 12/24/2012"; /适应 于 2012 年 的 文本 内 容 
09 function next_year($matches) /定义 回调 函数 
10 { 

11 // 通 常 : $matches[0] 是 完整 的 匹配 项 

12 //$matches[1] 是 第 一 个 括号 中 的 子 模式 的 匹配 项 

13 // 以 此 类 推 

14 return $matches[1].($matches[2]+1); // 返 回 函 数 的 内 容 
15 

16 echo $text; 

17 echo "«p»"; 

18 echo preg replace callback("|(id(2/Ad(2V/)(d(4))|","next year",$text); /执行 操作 

19 2?» 

20 </body> 

21 «html» 


在 PHP 运行 环境 中 执行 该 PHP 文件 ， 执 行 结果 如 图 12.17 所 示 。 


0401 


BASE. orco E 


Xue - | 


12.17 ”preg_replace_callback() 函 数 使 用 实例 执行 结果 


(0 PHP 网 络 编程 技术 详解 


12.3.7 ”执行 正则 表达 式 的 搜索 与 替换 
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EE 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 12 章 \ 执 行 正 则 表达 式 的 搜索 与 替换 ,wmv 
mixed preg_replace(mixed pattern,mixed replacement,mixed subject[,int limit]) 


该 函数 执行 正则 表达 式 的 搜索 和 替换 。 在 subject 中 搜索 与 pattern 模式 相 匹 配 的 项 ， 并 替换 为 
replacement 参数 。 如 果 指 定 了 limit 参数， 则 仅 蔡 换 limit 个 匹配 。 如 果 省 略 limit 参数 或 者 其 值 为 -1， 
则 所 有 的 匹配 项 都 会 被 替换 。 

注意 : limit 参 数 是 PHP 4.0.1 加 入 的 。 


【实例 12-18】 以 下 代码 演示 preg_repalce0 函 数 是 如 何 进行 搜索 与 替换 的 。 


源码 路 径 : 光盘 \ 源 文件 \12\12-18.php 


re | 实例 12-18，preg repalce() 函 数 如 何 进行 搜索 与 替换 


<html> 
<head> 
<title>preg_replace () 函 数 使 用 实例 </title> 
</head> 
<body> 
<?php 
$search = array( 
"«script[^» ]*2».*? «/script»'si", 
"<[V"?[^<>] ?> si 
"(NAnJ)AsJ+", 
"&(quot|#34);'i", 
"&(amp|4/38);'", 
"'&(Itj60);'", 
"&(gt/62);'i", 
"&(nbsp|*160);'i", 
"&(iexcl|£*161);'i", 
"&(cent|*162);'i", 
"&(pound[4163);'i", 
"&(copy[/4169);'i", 
"&#(\d+);'e"); 
$replace = array ("", 
NES 
m 
"&", 
"en, 
">, 
chr(161), 
chr(162), 
chr(163), 
chr(169), 
"chr(M)"); 


/去 掉 JavaScript 
/去 掉 HTML 标记 
/去 掉 空白 字符 

Ii HTML. 实体 


/作为 PHP. 代码 运行 


$document="<b>l love this game</b><p><u><h1> 用 PHP 编程 是 一 件 很 简单 的 事 </h1></u><p><b> 


第 12 章 PHP 中 正则 表达 式 的 使 用 


<i><h2>HELLO WORLD! </h2></i></b>"; /定义 $doucment 变量 

35 $text = preg_replace ($search, $replace, $document); /使 用 preg_replace() 函 数 进行 处 理 
36 echo "原来 的 内 容 为 : “; 

37 echo $document; 

38 echo "<p>"; 

39 echo "经 过 preg replace 处 理 之 后 的 内 容 为 : "; 

40 echo $text; 

41 ?> 

42 </body> 

43 </html> 


在 PHP 运行 环境 中 执行 该 PHP 文件 ， 执 行 结果 如 图 12.18 所 示 。 


@ 2) [E rpJ/Jlocahost12-152hp P ~ Ò | S preg.ropiace ouat.. “| 
| REDAREA: Tove this game 


HELLO WORLD ! 


经 过 prcg_rcplacc 处 理 之 后 的 内 容 为 ，Ilove this gamc 有 PHP 编程 是 一 什 很 简单 的 事 HELLO WORLD! 


Ai ~ 


图 12.18 ”preg_replace() 函 数 使 用 实例 执行 结果 
从 图 12.18 执行 结果 可 以 发 现 ， 经 过 preg_replace0 函 数 的 处 理 ， 原 来 包含 HTML 格式 的 内 容 ， 全 
部 被 转换 成 了 普通 字符 输出 。 


12.3.8 ”用 正则 表达 式 分 割 字符 串 


E 知识 点 讲解 : 光盘 \ 视 频 讲 解 \ 第 12 章 \ 用 正则 表达 式 分 割 字符 囊 .wmv 
array preg split(string pattern,string subject[,int limit[,int flags]]) 
该 函数 使 用 正则 表达 式 分 割 字 符 串 。 返 回 一 个 数组 ,包含 subject 中 沿 着 与 pattern 模式 匹配 的 边界 
所 分 割 的 子囊 。 如 果 指定 了 limit 参数 ， 则 最 多 返回 limit 个 子 串 ， 如 果 没 有 指定 limit 参数 或 者 其 值 是 
-1， 则 意味 着 没有 限制 ， 可 以 用 来 继续 指定 可 选 参数 flags。 
flags 可 以 是 下 列 标 记 的 任意 组 合 〈 用 按 位 或 运算 符 组 合 ) : 
PREG SPLIT NO_EMPTY: 如 果 设 定 了 本 标记 ， 则 preg_split0 函 数 只 返回 非 空 的 成 分 ; 
PREG SPLIT DELIM CAPTURE: 如 果 设 定 了 本 标记 ， 定 界 符 模式 中 的 括号 表达 式 也 会 被 捕 
获 并 返回 。 
PREG SPLIT OFFSET CAPTURE: 如 果 设 定 了 本 标记 ， 对 每 个 出 现 的 匹配 结果 也 同时 返 
其 附属 的 字符 串 偏 移 量 。 
【实例 12-19】 以 下 代码 演示 preg_split() 函 数 是 如 何 对 字符 串 进行 分 割 的 。 


Tz 


区 实例 12-19: preg_split() 函 数 如 何 对 字符 串 进行 分 割 
源码 路 径 光盘 \ 源 文件 \12\12-19.php 


M LI d 


02 <head> 

03 ”<title>preg_split() 函 数 使 用 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 Sstr-'string'; 

08 S$chars-preg. split(//','$strj-1,PREG, SPLIT NO EMPTY); 。 // 使 用 PREG SPLIT NO EMPTY 3 
数 对 字符 串 进行 分 割 ， 结 果 保存 到 数组 $chars 中 

09 for($i-0;Si«count($chars);Si---) // 通 过 循环 输出 数组 
10 " 

11 echo $chars[Si]; 


图 12.19. ”preg_split() 函 数 使 用 实例 执行 结果 
12.4 正则 表达 式 使 用 实例 


前 两 节 为 读者 介绍 了 PHP 中 正则 表达 式 的 元 字符 、 表 达 式 语法 、 正 则 表达 式 的 函数 。 经 过 前 两 节 
的 学 习 , 相信 读者 对 在 PHP 中 如 何 使 用 正则 表达 式 都 有 一 个 比较 清晰 的 认识 了 。 本 节 将 通过 一 些 实例 ， 
来 向 读者 做 进一步 的 说 明 。 这 些 实例 都 是 在 平常 编程 过 程 中 经 常 可 能 用 到 的 功能 ， 了 解 和 使 用 这 些 实 
例 对 以 后 使 用 PHP 编写 Web 程序 将 起 到 事半功倍 的 效果 。 


12.4.1 ”构造 检查 Email 的 正则 表达 式 
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本 小 节 来 讨论 怎么 验证 一 个 Email 地 址 。 通 常 一 个 完整 的 Email 地 址 中 有 3 个 部 分 : POP 3.0 用 户 
名 (在 “@” 左 边 的 内 容 ) 、“@” 和 服务 器 名 〈 就 是 剩 下 那 部 分 ) 。 用 户 名 可 以 含有 大 小 写字 母 阿 
拉 伯 数字 、 句 号 (“.”) 、 减 号 (“-”) 以 及 下 划 线 (“_”) 。 服 务 器 名 字 也 是 符合 这 个 规则 ， 当 
然 下 划 线 除外 。 

现在 ， 用 户 名 的 开始 和 结束 都 不 能 是 名 点， 服务 器 的 名 称 也 是 这 样 。 还 有 用 户 名 中 不 能 有 两 个 连 
续 的 句点 ， 它 们 之 间 至 少 应 存在 一 个 字符 。 下 面 就 来 说 明 怎么 为 用 户 名 写 一 个 匹配 模式 。 

^L a-zA-Z0-9-]4$ 
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现在 的 情况 还 不 允许 句号 的 存在 。 把 它 加 上 : 

^L a-zA-Z0-9-]4(.[ a-zA-Z0-9-]-)*$ 

上 面 的 正则 表达 式 模式 的 意思 是 : “以 至 少 一 个 规范 字符 〈 除 .以 外 ) 开头 ， 后 面 跟着 0 个 或 者 多 
个 以 点 开始 的 字符 串 ”。 

要 使 上 面 的 正则 表达 式 模式 更 简化 一 点 ， 可 以 用 eregi() 函 数 取代 ereg0 函 数 。 因 为 eregi() 函 数 在 进 
行 正则 表达 式 模式 匹配 时 忽略 字母 字符 的 大 小 写 ， 这 样 就 不 需要 指定 两 个 范围 ，“a-z” 和 “A-Z”， 
只 需要 指定 一 个 就 可 以 了 。 改 进 之 后 的 正则 表达 式 模式 如 下 所 示 : 

^[ a-z0-9-]*(V[ a-z0-9-]*)*$ 

后 面 的 服务 器 名 字 也 是 一 样 ， 但 要 去 掉 下 划 线 : 

A[a-z0-9-]+(\.[a-z0-9-]+)*$ 

设 定好 了 用 户 名 及 主机 名 的 规则 ， 现 在 要 做 的 只 需要 用 “@” 符 号 把 用 户 名 及 主机 名 两 部 分 内 容 
连接 起 来 : 

^[_a-z0-9-]+(\.[_a-z0-9-]+)*@[a-z0-9-]+(\.[a-z0-9-]+)*$ 

这 就 是 完整 的 Email 认证 匹配 模式 了 ， 只 需要 调用 : 

eregi("^[_a-z0-9-]+(\.[_a-z0-9-]+)*@[a-z0-9-]+(\.[a-z0-9-]+)*$",$eamil) 

就 可 以 得 出 目标 字符 串 是 否 为 正确 的 Email 地 址 了 。 

【实例 12-20】 以 下 代码 演示 使 用 上 面 定 义 的 匹配 模式 匹配 Email 地 址 。 


TE 。 实例 12-20， 使 用 上 面 定义 的 匹配 模式 匹配 Email 地址 
源码 路 径 : 光盘 \ 源 文件 12\12-20php 0000000000000 000000, 


01 «html» 

02 <head> 

03 ”<title> 使 用 正则 表达 式 检查 Email 地 址 </title> 

04 </head> 

05 <body> 

06 <?php 

07 $string1-"usemame(hostname.com"; /定义 变量 $string1 
08 $string2="user.name@host.com.cn"; // 定 义 变量 $string2 
09 $string3-"Q"; /定义 变量 $string3 
10 $string4-"username&hostname.com"; /定义 变量 $string4 
11 function panduan($string) // 基 于 正则 定义 判断 函数 
12 { 

13 if(eregi("^[_a-z0-9-]+(\.[_a-z0-9-]+)*@[a-z0-9-]+(\.[a-z0-9-]+)*$",$string)) 。 /判断 
14 echo $string.": 是 正确 的 Email 地 址 "; 

15 else 

16 echo $string.": 不 是 Email 地 址 ! "; 

17 n 

18 panduan($string1 ); 

19 echo "<p>"; 

20 panduan(S$string2); 

21 echo "<p>"; 


KA aaa 


22 panduan($string3); 
23 echo "<p>"; 

24 panduan(Sstring4); 
25 ?> 

26 </body> 

27 «html» 


在 PHP 运行 环境 下 执行 该 PHP 文件 ， 执 行 结果 如 图 12.20 所 示 。 


usemame@hostname com， 是 正确 的 Email 址 | | 
username@hostcom cn， 是 正确 的 Email 地 址 1 

@: 不 是 Email 地 址 ! 

username&hostname com， 不 是 Email 地 址 ! 


1220 ”使 用 正则 表达 式 检查 Email 地 址 执行 结果 
124.2 ”对 图 像 UBB 代码 进行 替换 
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使 用 过 网 上 留言 竹 、 论 坛 的 用 户 都 知道 ， 一 般 情况 下 为 了 保证 网 络 的 安全 是 不 允许 用 户 直 接 使 用 
HTML 代码 的 。 但 是 有 的 留言 每、 论坛 等 Web 程序 却 允许 用 户 使 用 UBB 代码 。UBB 实际 上 就 是 把 用 
户 输 入 的 特定 内 容 转化 为 无 害 的 HTML 代码 ， 这 样 既 保 证 了 安全 ， 又 可 以 使 用 户 实现 如 贴图 、 发 送 移 
动 文字 、 粘 贴 程序 代码 等 功能 。 本 小 节 就 带领 读者 来 实现 如 何 把 图 像 UBB 内 容 转 化 为 带 有 图 像 的 HTML 
代码 。 
UBB 图 像 代码 的 格式 一 般 如 下 所 示 : 
[img]url[/img] 
其 中 的 url 是 指向 一 幅 图 片 的 地 址 。 
列 出 了 和 欲 替换 内 容 的 格式 ， 思 路 就 很 清晰 了 。 匹 配 内容 为 : 以 “[img]” 开 头 以 “[/img]” 结 尾 的 内 
即 上 边 的 url 部 分 。 
\[imgy(.+)\[Vimg\] 
查找 出 内 容 之 后 就 是 替换 了 ,把 它 蔡 换 成 HTML 代码 <img src=url>。 这 样 就 完成 所 要 求 的 操作 了 。 
调用 eregi_replace0 函 数 : 


X 


eregi_replace("\[img\]","<img src-" Sinput); 

eregi_replace("\[Vimg\]",">", $input); 

这 样 就 完成 了 对 UBB 图 像 标记 首尾 的 替换 。 这 里 为 什么 要 调用 eregi_replace() 函 数 ， 而 不 是 
ereg_replace() 函 数 呢 ? 因为 用 户 在 输入 时 很 有 可 能 不 会 区 分 大 小 写 ， 即 大 小 写 两 种 情况 都 有 可 能 发 生 ， 
所 以 要 采用 忽略 大 小 写 的 eregi_replace() 函 数 。 

【实例 12-21】 以 下 代码 验证 图 片 的 替换 是 否 能 正常 运行 。 


e. 
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re 实例 12-21: 验证 图 片 的 替换 是 否 能 正常 运行 
源码 路 径 光盘 \ 源 文件 \12\12-21.php 


01 <html> 

02 <head> 

03 ”<title> 对 图 像 UBB 代码 进行 替换 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 $string1-"[img]1 jpg[/img]"; /定义 变量 $string1 
08 $string2-"[IMG]2 jpg[/IMG]"; /定义 变量 $string2 
09 $temp1-eregi replace("W[imgW"," «img src=",$string1); 
10 $temp1-eregi replace("[VimgV","»",$temp1); 

11 $temp2-eregi replace("[imgl]","«img src=",$string2); 
12 $temp2-eregi replace("([VimgW","»",$temp2); 

13 echo "<table border=1>"; 

14 echo "<tr>"; 

15 echo "<td>string1 的 内 容 为 : <p>".$string1."</td>"; 

16 echo "<td>string2 的 内 容 为 : <p>".$string2."</td>"; 

17 echo "</tr>"; 

18 echo "<tr>"; 

19 echo "<td> 将 string1 转化 后 的 内 容 为 : «p»".Stemp1."«/td»"; 
20 echo "<td> 将 string2 转化 后 的 内 容 为 :<p>".$temp2."</td>"; 
21 echo "</tr>"; 

22 echo "</table>"; 

PE 

24 </body> 

25 </html> 


在 PHP 运行 环境 下 执行 该 PHP 文件 (在 执行 该 文件 之 前 , 要 把 名 为 Ljpg 及 2.jpg 的 两 个 图 像 文件 
放 到 该 PHP 文件 同一 路 径 下 ) ， 执 行 结果 如 图 12.21 所 示 。 


[EN 
[€] [B/D a 
AAA, UAE 
Tang) jpul uz] [IMG]2 jpe [IMG] 
IF sin 化 启 的 内 容 为 ， 
m 
将 sring 转化 后 的 内 容 为 ， 
1 
Aie v 


图 12.21 对 图 像 UBB 代码 进行 替换 实例 执行 结果 
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从 图 1221 可 以 发 现 ， 经 过 对 图 像 的 替换 操作 ， 把 原本 为 UBB 代码 的 内 容 转化 成 了 HTML. 内 容 ， 而 
在 Web 页 面 上 显示 HTML 内 容 ， 就 显示 出 了 图 片 ， 从 而 说 明 图 像 蔡 换 正 则 表达 式 的 执行 结果 是 正确 的 。 

除了 常见 的 查找 、 蔡 换 功 能 之 外 ， 正 则 表达 式 还 具有 如 下 两 个 功能 : 

A RFE 

ereg( fll. eregiO 函 数 有 一 个 特性 是 允许 用 户 通过 正则 表达 式 去 提取 字符 串 的 一 部 分 。 如 想 从 
path/URL 中 提取 文件 名 就 可 以 执行 下 面 的 操作 : 


ereg("((^V]*)$",SpathOrUrl,Sregs); 


echo $regs[1]; 

EDO AR 

ereg_replace() 和 eregi_replace() 函 数 也 是 非常 有 用 的 。 假设 用 户 想 把 所 有 的 间隔 符号 都 奉 换 成 逗号 ， 
就 可 以 使 用 这 样 的 操作 : 


ereg replace("[ IMA", ",", trim($str)); 
125 AR € ^X 


本 章 为 读者 介绍 了 PHP 中 的 正则 表达 式 ， 带 领 读 者 一 步 步 由 简 入 繁 地 学 习 了 什么 是 正则 表达 式 、 
正则 表达 式 的 构成 、 正 则 表达 式 的 语法 、Perl 兼容 的 正则 表达 式 函 数 ， 以 及 通过 具体 的 实例 来 进一步 
巩固 了 正则 表达 式 的 使 用 。 正 如 本 章 开头 所 说 的 那样 : 正则 表达 式 在 进行 PHP 编程 中 有 着 相当 广泛 的 
应 用 。 通 过 本 章 的 学 习 ， 相 信 读 者 已 经 熟练 地 掌握 了 正则 表达 式 的 知识 ， 这 将 会 使 以 后 的 Web 编程 工 
作 变 得 更 加 轻松 。 


12.6 A € 3 


习题 12-1 创建 一 个 判断 一 串 数字 是 否 为 手机 号 的 正则 表达 式 : 
习题 12-2 ”使 用 ereg_replace() 函 数 将 如 下 字符 串 中 的 所 有 “o” 替 换 为 “O”。 
A pound of pluck is worth a ton of luck. 
【分 析 】 该 习题 考查 读者 对 ereg_replace() 函 数 的 掌握 。 
【关键 代码 】 
S$strzereg replace('o','O' $str); 
2]88 12-3 ”使 用 split0) 函 数 将 习题 12-1 中 的 字符 串 以 “o” 为 分 隔 符 进 行 分 割 ， 并 将 分 割 后 的 子 串 
输出 。 
【分 析 】 该 习题 考查 读者 对 splitO 函 数 的 掌握 。 
【关键 代码 】 
Sstr-splito' Sstr); 


e. 
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习题 12-4 ”使 用 preg_grepO 函 数 将 如 下 数组 中 的 字符 元 素 存 入 另 一 个 数组 ， 并 输出 新 数组 的 详细 
信息 。 
array(hello',1,'nihao',43,good',37) 
【分 析 】 该 习题 考查 读者 使 用 preg_grep0 函 数 的 能 力 。 
【关键 代码 】 
$new_arr=preg_grep('#[a-z]#,$arr); 


第 13 章 PHP 面向 对 象 编程 


通常 的 编程 语言 所 使 用 的 编程 方式 有 两 种 : 面向 过 程 方式 ， 如 C 语言 所 采用 的 方式 ， 面 向 对 象 方 
XX, "Java 所 采用 的 方式 。PHP 是 一 种 混合 语言 ， 它 同时 兼 有 面向 过 程 和 面向 对 象 这 两 种 方式 。 具 体 
使 用 哪 种 方式 ， 完 全 取决 于 用 户 的 选择 。 两 种 方式 各 有 优 劣 。 本 章 将 重点 介绍 PHP 中 的 面向 对 象 编程 
COOP) 。 内 容 包括 : 面向 对 象 编程 的 基础 、 什 么 是 类 、 为 什么 要 用 到 类 、 在 PHP 程序 中 如 何 使 用 对 
象 、 类 的 封装 、 为 类 添加 属性 、 为 类 添加 方法 、 类 的 继承 、 类 的 重 载 、 类 的 引用 、 类 的 构造 函数 及 PHP 
中 与 类 、 对 象 相关 的 函数 和 类 的 具体 使 用 实例 等 。 通 过 本 章 的 学 习 ， 读 者 会 对 在 PHP 中 使 用 对 象 有 一 
个 全 面 的 认识 。 


13.1 面向 对 象 编程 (OOP ) 的 基础 
要 想 使 用 面向 对 象 编程 CObject-Oriented-Program, OOP) ， 首 先 要 了 解 什么 是 面向 对 象 。 本 节 就 
来 回答 什么 是 面向 对 象 、 面 向 对 象 的 构成 以 及 什么 是 类 、 为 什么 要 用 到 类 的 问题 。 
13.1.4 什么 是 类 (CLASS) 
GE 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 13 章 \ 什 么 是 类 .wmv 


在 了 解 什么 是 类 之 前 ， 先 来 了 解 一 下 面向 对 象 。 在 前 儿童 为 读者 所 提供 的 实例 中 ， 使 用 的 代码 基 
本 上 都 是 面向 过 程 的 。 面 向 过 程 的 代码 一 般 形 如 : 


<?php 
echo "HELLO WORLD!"; 
?» 
这 就 是 通常 所 用 到 的 方法 ， 但 是 可 以 达到 同一 个 目的 、 面 向 对 象 的 代码 形 如 : 
01 <?php 
02 class helloworld /定义 一 个 类 
03 { 
04 function myprint() /该 类 的 一 个 方法 
05 ( 
06 print "hello, world."; // 该 类 的 方法 所 实现 的 功能 是 打印 字符 串 
07 l 
08 H 
09 S$myhelloworld =new helloworld(); /为 类 初始 化 一 个 实例 〈 对 象 ) 
10 $myhelloworld->myprint(); // 调 用 该 实例 的 方法 


11 ?> 


soe PHP 面 和 对 家 信奉 SA 


说 明 : 读者 在 这 里 无 需 理解 上 面 代码 的 具体 含义 。 


上 面 这 段 代 码 就 是 标准 的 面向 对 象 的 做 法 ， 即 为 了 完成 一 件 事 ， 先 定义 一 个 类 ， 然 后 给 该 类 添加 
相应 的 方法 ， 再 为 该 类 实例 化 一 个 对 象 ， 让 对 象 去 执行 相应 的 方法 ， 从 而 完成 所 需要 的 工作 。 

上 例 中 helloworld 是 一 个 类 ， 通 过 在 类 中 添加 一 个 现在 可 以 看 作 是 一 个 函数 的 方法 myprint). iz 
方法 完成 的 工作 就 是 输出 一 个 字符 串 “hello, world.”。 而 Smyhelloworld 则 是 类 helloworld 的 一 个 对 象 。 

从 以 上 两 组 代码 中 ， 读 者 应 该 能 够 看 出 面向 过 程 与 面向 对 象 的 区 别 。 

面向 过 程 的 基础 是 一 名 一句 的 代码 ， 而 面向 对 象 的 基础 则 是 对 象 。 

那么 下 面 就 来 介绍 什么 是 类 。 抛 开 各 种 教材 的 定义 ， 通 俗 一 点 来 说 ，“ 类 ”就 是 “一 类 事物 ”的 简 
称 。 什 么 可 以 作为 “类 ” 呢 ? 人 ! “人 ”就 是 一 个 类 ， 与 这 个 类 相 区 别 ，“ 动 物 ” 和 “植物 ”就 是 另外 
的 两 个 类 。 也 就 是 说 ， 类 是 具有 相同 的 属性 定义 和 行为 表现 的 事物 的 集合 。 以 “人 ”为 例 ， 这 个 类 具有 
“国籍 ”、“ 种 族 ”、“ 年 龄 ”、“ 姓 名 ”等 属性 定义 ， 也 具有 “走路 ”、“ 工 作 ” 等 行为 表现 。 

但 是 ， 类 不 是 指 个 体 ， 我 们 可 以 说 人 具有 国籍 ， 但 不 能 说 “人 ”这 个 类 的 “国籍 ”是 什么 ， 因 为 
“国籍 ”这 个 属性 的 表现 是 要 随 着 类 的 具体 化 而 实现 的 ， 就 是 说 ， 需 要 具体 到 类 中 的 一 个 单个 的 元 素 ， 
即 这 个 类 的 一 个 “实例 ”。 类 是 虚无 的 东西 ， 一 个 概念 名 词 而 已 。 真 正 用 到 的 是 类 的 实例 ， 即 对 象 。 
如 一 个 公司 ， 它 的 雇员 是 一 个 个 具体 的 人 ， 而 不 是 整个 “人 类 ”。 和 套用 一 些 教材 里 的 话 : 类 是 现实 世 
界 某 些 对 象 的 共同 特征 〈 属 性 和 操作 ) 的 表示 ， 对 象 是 类 的 实例 。 

总 而 言 之 ， 类 是 变量 〈 类 的 属性 ) 与 作用 于 这 些 变量 的 函数 〈 类 的 方法 ) 的 集合 ， 属 性 与 方法 是 
构成 类 的 基础 。 


13.1.2 ”为 什么 要 用 到 类 


GE 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 13 章 \ 为 什么 要 用 到 类 .wmv 

面向 过 程 编程 存在 一 个 痊 端 ， 即 代码 重用 时 非常 困难 。 这 在 大 规模 编程 中 表现 得 尤其 突出 。 面 向 
过 程 编程 时 ， 如 果 用 大 量 的 代码 来 完成 一 个 工作 ， 当 需要 重用 时 ， 唯 一 的 方法 就 是 重新 调用 这 些 代码 。 
任务 量 非常 大 ， 而 且 很 容易 出 错 。 

面向 过 程 的 这 个 整 端 在 面向 对 象 编程 模式 中 得 到 了 很 好 的 解决 。 类 对 代码 进行 了 封装 ， 所 以 在 进 
行 重用 时 就 显得 非常 方便 ， 只 需要 调用 相关 类 的 方法 或 属性 即 可 。 


回 ” 易 维护 。 采 用 面向 对 象 思想 设计 的 结构 ， 可 读 性 高 ， 由 于 继承 的 存在 ， 即 使 改变 需求 ， 维 护 
也 只 是 在 局 部 模块 ， 所 以 维护 起 来 是 非常 方便 的 。 

Ep ”质量 高 。 在 设计 时 ， 可 重用 现 有 的 、 在 以 前 的 项 目 领域 中 已 被 测试 过 的 类 ， 使 系统 满足 业务 
需求 并 具有 较 高 的 质量 。 

回 ”效率 高 。 在 软件 开发 时 ， 根 据 设 计 的 需要 对 现实 世界 的 事物 进行 抽象 ， 产 生 类 。 使 用 这 样 的 
方法 解决 问题 ， 接 近 于 日 常生 活 和 自然 的 思考 方式 ， 势 必 提 高 软件 开发 的 效率 和 质量 。 

回 ” 易 扩展 。 由 于 继承 、 封 装 、 多 态 的 特性 ， 自 然 设 计 出 高 内 聚 、 低 耦合 的 系统 结构 ， 使 得 系统 
更 灵活 、 更 容易 扩展 ， 而 且 成 本 较 低 。 

由 于 与 面向 过 程 的 方法 相 比 具有 以 上 优点 ， 所 以 在 进行 大 型 项 目的 开发 时 使 用 PHP 面向 对 象 的 编 


程 方法 是 必要 的 。 
8) 
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13.2. Æ PHP 中 创建 和 使 用 类 


以 前 在 介绍 变量 时 就 曾 提 到 过 ， 变 量 有 几 种 类 型 ， 其 中 有 两 种 类 型 比较 特殊 ， 一 种 是 数组 ; 另外 
一 种 就 是 对 象 。 在 PHP 中 ， 对 象 可 以 看 成 是 一 种 特殊 的 变量 ， 对 象 有 属性 、 方 法 。PHP 中 具体 怎么 创 
建 并 使 用 类 呢 ? 本 节 就 来 回答 这 个 问题 。 


13.2.1 自 建 类 一 一 类 的 封装 
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前 面 提 到 过 ， 类 是 变量 与 作用 于 这 些 变量 的 函数 的 集合 ， 所 以 要 创建 类 就 离 不 开 变量 与 函数 。 在 
介绍 如 何 自 建 类 之 前 ， 先 来 看 一 个 实例 。 下 面 代码 给 出 了 如 何 创建 一 个 类 ， 并 为 类 实例 化 一 个 对 象 及 
调用 类 的 方法 。 

1. 创建 类 

在 使 用 一 个 类 之 前 必须 要 先 创建 类 ， 创 建 类 的 语法 结构 如 下 : 


class classname 
{ 
) 


说 明 : 上 面 代码 定义 一 个 最 简单 的 类 ， 它 没有 任何 内 容 。 
创建 类 的 方法 由 一 个 class 关键 字 加 一 个 类 的 名 称 构成 。 以 下 实例 构建 一 个 购物 车 cart 类 。 代码 如 下 : 


01 <?php 

02 class cart 

03 f 

04 private $items; /购物 车 中 的 物品 

05 function add item(Sartnr,$num) /将 $num 个 $artnr 物品 加 入 购物 车 
06 { 

07 Sthis-^items[Sartnr] -$num; // 现 有 数量 加 上 放 入 数量 

08 n 

09 function remove item(Sartnr,$num) // 将 $num 个 $artnr 物品 从 购物 车 中 取出 
10 { 

11 if(Sthis-"items[Sartnr]» $num) // 如 果 取 出 数量 小 于 现 有 总 数 

12 { 

13 Sthis-»items[Sartnr]--$num; // 现 有 数量 减 去 取出 数量 

14 return true; IEAA 

15 } 

16 elseif($this->items[$artnr]==$num) // 如 果 要 取出 数量 与 现 有 数量 相等 
17 { 

18 unset($this->items[$artnr]); // 清 空 现 有 数量 值 

19 return true; 

20 n 

21 else // 如 果 取 出 数量 大 于 现 有 数量 


soe meone SA 


23 return false; // 返 回 错误 


上 面 的 代码 创建 了 一 个 名 为 cart 的 类 。 该 类 由 购物 车 中 的 商品 构成 的 数组 和 两 个 用 于 从 购物 车 中 
添加 和 删除 商品 的 函数 组 成 。 接 下 来 再 来 讲解 如 何 为 类 实例 化 一 个 对 象 。 


2. 创建 对 象 

只 创建 了 类 ， 而 不 为 类 实例 化 一 个 对 象 ， 那 么 类 就 不 会 起 作用 。 创 建 一 个 类 的 目的 就 是 要 使 用 类 
来 实例 化 对 象 。 下 面 就 来 介绍 ， 如 何 为 类 实例 化 对 象 。 

创建 对 象 的 语法 如 下 : 

$objectname=new classname 

即 “对 象 名 〈 记 得 前 面 的 美元 符号 ) + 符号 “=”+new+ 类 名 ” 即 可 。 

而 下 面 的 例子 就 创建 了 $mycart 这 样 一 个 基于 类 cart 的 对 象 ， 如 下 所 示 。 


$mycart=new cart; /| 创建 $mycart 对 象 
$mycart->add_item("5",3); // 调 用 $mycart 对 象 的 放 入 购物 车 方法 


上 例 中 的 Smycart 具有 方法 add_item(), remove_item() 和 一 个 items 变量 , 它们 都 是 明显 的 函数 和 变 
量 。 在 引用 对 象 的 变量 与 函数 时 使 用 :， Smycart-»items 及 $mycart->add_item()。 所 以 调用 一 个 对 象 的 变 
量 与 函数 使 用 下 面 的 语法 格式 : 
S$objectname-»varname; 
Sobjectname-»functionname; 


在 使 用 一 个 对 象 时 有 一 个 问题 需要 注意 ， 如 上 例 中 的 变量 名 为 Smycart->items， 不 是 Smycart-> 
$items， 屠 是 因为 在 PHP 中 一 个 变量 名 只 有 一 个 单独 的 美元 符号 。 

另外 ， 在 定义 类 时 ， 无 法 得 知 将 使 用 什么 名 字 的 对 象 来 访问 。 如 在 编写 cart 类 时 ， 并 不 知道 后 面 
对 象 的 名 称 将 会 命名 为 Smycart 或 者 其 他 的 名 称 。 因 而 不 能 在 类 中 使 用 $mycart->items 。 然 而 为 了 类 定 
义 的 内 部 访问 自身 的 函数 和 变量 ， 可 以 使 用 伪 变 量 $this 来 达到 这 个 目的 。S$this 变量 可 以 理解 为 “我 自 
己 的 ”或 者 “当前 对 象 ”。 因 而 '$this->items[$artnr]+=$num' 可 以 理解 为 “我 自己 的 物品 数组 的 $artnr 计 
数 器 加 $num” 或 者 “在 当前 对 象 的 物品 数组 的 Sartnr 计数 器 加 Snum” 。 

【实例 13-1】 下 面 把 前 面 的 例子 代码 加 以 完善 ， 让 其 有 实际 的 执行 结果 ， 从 而 使 读者 直观 地 认识 
到 如 何 定义 类 、 实 例 化 对 象 、 引 用 类 的 变量 及 函数 。 


re 实例 13-1: 使 读者 直观 地 认识 到 如 何 定义 类 、 实 例 化 对 象 、 引 用 类 的 变量 及 函数 
源码 路 径 光盘 \ 源 文件 \13\13-1.php 


02 <head> 
03 ”<title> 定 义 与 使 用 类 实例 </title> 
04 </head> 
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05 <body> 
06 <?php 

07 class cart 

08 ( 

09 public Sitems; 

10 function add item(Sartnr,$num) 

11 7 

12 if(lisset($this-»items[Sartnr])) 

13 Sthis-»items[Sartnr]-$num; 
14 else 

15 $this->items[$artnr]+=$num; 
16 

17 function remove_item($artnr, $num) 

18 { 

19 if($this->items[$artnr]>$num) 

20 { 

21 S$this-»items[Sartnr]--$num; 
22 return true; 

23 ) 

24 elseif(Sthis-»items[Sartnr]--$num) 
25 n 

26 unset(Sthis-»items[Sartnr]); 
27 return true; 

28 ) 

29 else 

30 

31 return false; 

32 ) 

33 ) 

34 

35 $mycart-new cart; 

36 $mycart-»add item("5",3); 

37 echo "在 实现 add_item(\"5\",3) 之 后 "; 

38 echo "<p>"; 

39 echo "当前 购物 车 内 编号 为 5 的 商品 数量 为 :"; 
40 echo $mycart-»items["5"]; 

41 echo "<p>"; 

42 $mycart-»add item("5",10); 

43 echo "在 实现 add_item(\"5\",10) 之 后 "; 

44 echo "<p>"; 

45 echo "当前 购物 车 内 编号 为 5 的 商品 数量 为 :"; 
46 echo $mycart->items["5"]; 

47 echo "<p>"; 

48 $mycart-»remove item("5" 7); 

49 echo "在 实现 remove_item(\"5\",7) 之 后 "; 

50 echo "<p>"; 

51 echo "当前 购物 车 内 编号 为 5 的 商品 数量 为 :"; 
52 echo $mycart-»items["5"]; 

53 ?> 

54 </body> 

55 </html> 


(m, 


/购物 车 中 的 物品 
// 将 $num 个 $artnr 物品 加 入 购物 车 


// 现 有 数量 加 上 放 入 数量 
// 将 $num 个 $artnr 物品 从 购物 车 中 取出 
// 如 果 取出 数量 小 于 现 有 总 数 


// 现 有 数量 减 去 取出 数量 
// 返 回 真 


// 如 果 要 取出 数量 与 现 有 数量 相等 
/清空 现 有 数量 值 


/如果 取出 数 比 现 有 数 还 要 大 


/| 返回 错误 


/| 创建 $mycart 对 象 
// 调 用 $mycart 对 象 的 放 入 购物 车 方法 


// 显 示 对 象 的 items["5"] 变 量 


IH Fi $Smycart 对 象 的 add_item() 函 数 


/ 旺 示 对 象 的 iiems["5"] 变 量 


/1 调用 $mycart 对 象 的 remove_item() 函 数 


/显示 对 象 的 iiems["5"] 变 量 
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在 PHP 运行 环境 下 执行 该 PHP 文件 ， 将 会 出 现 如 图 13.1 所 示 的 执行 结果 。 


当前 购物 丰 内 编号 为 3 的 商品 赦 量 为 ,3 
在 实现 add_ item("'3".109) 之 后 

当前 购物 车 内 编号 为 5 的 商品 数量 为 ，13 
在 实现 remove_iten("5",7 之 后 

当前 购物 车 内 编号 为 5 的 商品 丈量 为 ,6 
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图 13.1 定义 与 使 用 类 实例 执行 结果 


从 图 13.1 可 以 看 出 ， 在 实现 add_item("5",3) 后 〈 即 向 购物 车 内 添加 3 个 编号 为 5 的 商品 ) ， 现 在 
购物 车 内 编号 为 5 的 商品 数量 为 3; 实现 add_item("5",10) 后 ( 即 向 购物 车 内 添加 10 个 编号 为 5 的 商品 )， 
数量 再 增加 10 变 为 13; 实现 remove_item("5",7)( 即 把 购物 车 内 编号 为 5 的 商品 减 去 7 个 ) 后 ， 数 量 
减 去 7 变 为 6。 说 明 类 通过 调用 类 的 方法 ， 改 变 了 对 象 的 某 些 属性 。 


13.2.2 ”为 类 添加 属性 
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使 用 class 语句 创建 类 后 ， 为 类 添加 必要 的 属性 〈 即 变量 ) 是 必要 的 也 是 必需 的 。 通 常情 况 下 ， 类 
都 有 属性 。 

现在 再 来 看 实例 13-1。 其 中 cart 是 一 个 类 ， 而 里 面 的 items 就 是 类 的 一 个 属性 。 类 的 属性 通俗 地 说 
也 就 是 存在 于 类 中 的 变量 。 

知道 了 这 样 的 概念 ， 就 明白 如 何 为 类 添加 属性 了 。 为 类 添加 属性 就 是 向 类 中 加 入 新 的 变量 。 

【实例 13-2】 以 下 代码 演示 如 何 为 类 添加 属性 。 


re 实例 13-2， 如 何 为 类 添加 属性 
源码 路 径 ， 光盘 \ 源 文件 \13\13-2.php 


01 <html> 

02 <head> 

03 ”<title> 为 类 添加 属性 使 用 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 class User // 首 先 定义 一 个 类 
08 { 

09 public $name; /用 户 的 名 字 
10 public $age; /用 户 的 年 龄 
11 public $sex; NAPE 
12 ) 

13 $user1=new User; /创建 一 个 对 象 
14 $user1->name="Jack"; /为 名 字 赋 值 
15 $user1->age="20"; /为 年 龄 赋值 
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16 $user1-»sex-"male"; /为 性 别 赋值 
17 echo "user 的 名 字 为 : "; 

18 echo $user1-»name; /显示 名 字 
19 echo "<p>"; 

20 echo "user1 的 年 龄 为 :"; 

21 echo $user1->age; /显示 年 龄 
22 echo "<p>"; 

23 echo "user1 的 性 别 为: "; 

24 echo $user1-»sex; /显示 性 别 
25 ?> 

26 </body> 

27 </html> 


在 PHP 运行 环境 下 执行 该 PHP 文件 ， 执 行 结果 如 图 13.2 所 示 。 


B mpllocalhost1: £ 


userl 的 名 字 为 ，Jack 


userl 的 年 龄 为 ，20 
userl 的 性 别 为 ，male 


| 


图 13.2 为 类 添加 属性 使 用 实例 执行 结果 
以 上 实例 中 ， 首 先 创建 了 一 个 类 User， 并 为 类 添加 了 3 个 属性 ， 分 别 为 用 户 的 名 字 、 年 龄 和 性 别 。 
然后 为 类 实例 化 一 个 对 象 Suser1， 给 对 象 的 每 个 属性 赋值 ， 调 用 对 象 的 属性 显示 出 相应 的 内 容 。 
在 类 中 ， 为 类 添加 属性 所 定义 的 变量 ， 可 以 使 用 public. protected 和 private 关键 字 来 定义 。 使 用 
public 修饰 的 变量 可 以 在 类 外 部 被 访问 ， 使 用 protected 和 private 修饰 的 变量 则 不 可 在 类 外 部 被 访问 。 


13.2.3 ”为 类 添加 方法 
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方法 就 是 类 中 的 函数 。 调 用 类 的 方法 其 实 就 是 执行 其 中 的 函数 ， 所 以 为 类 添加 方法 ， 也 就 是 给 类 
增加 函数 。 

仍然 通过 实例 13-1 来 研究 如 何 为 类 添加 方法 。 在 实例 13-1 中 ，cart 是 一 个 类 ， 它 有 两 个 函数 ， 即 
add_item() 和 remove_item() 函 数 ， 而 这 两 个 函数 也 就 是 类 cart 的 方法 。 要 实现 为 类 添加 方法 ， 只 需 向 类 
中 加 入 新 的 函数 即 可 。 

【实例 13-3】 以 下 代码 演示 如 何 为 类 添加 方法 。 


实例 13-3: 为 类 添加 方法 
- 源码 路 径 ， 光盘 \ 源 文件 \13\13-3.php 


02 <head> 

03 ”<title> 为 类 添加 方法 使 用 实例 </title> 
04 </head> 

05 <body> 
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06 <?php 

07 class Window // 首 先 定义 一 个 类 
08 f 

09 public $state; // 窗 户 的 状态 

10 function close window() // 关 窗户 方法 

11 i 

12 $this->state="close"; /窗户 的 状态 为 关 
13 return true; 

14 

15 function open_window() // 开 窗户 方法 

16 

17 Sthis-»state-"open"; /窗户 的 状态 为 开 
18 return true; 

19 } 

20 } 

21 $mywindow-new Window; /创建 一 个 对 象 

22 $mywindow-»state-"open"; /| 窗户 的 初始 状态 为 开 
23 echo "当前 mywindw 的 状态 为 :"; 

24 echo $mywindow->state; // 显 示 窗户 的 状态 
25 echo "<p>"; 

26 $mywindow-»close window(); // 调 用 关 窗 户 的 方法 
27 echo "经 过 close_windw() 处 理 后 的 的 状态 为 : "; 

28 echo $mywindow->state; /显示 窗户 的 状态 
29 echo "<p>"; 

30 $mywindow-»open window(); // 调 用 开 窗 户 的 方法 
31 echo "经 过 open_windw() 处 理 后 的 的 状态 为 : "S 

32 echo $mywindow->state; /显示 窗户 的 状态 
33 ?> 

34 </body> 

35 </html> 


在 PHP 运行 环境 中 执行 该 PHP 文件 ， 执 行 结果 如 图 13.3 所 示 。 
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Ga 
当前 mywindw 的 状态 为 ，open 

经 过 clese_windw0 处 理 后 的 的 决 态 为 ，close 

|| 经 过 open_windwO 处 理 后 的 的 状态 为 ，open 
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图 13.3 为 类 添加 方法 使 用 实例 执行 结果 


以 上 实例 中 ， 定 义 了 一 个 Window 类 ， 并 为 类 添加 了 Sstate 属性 ， 即 窗户 的 开关 状态 。 然 后 为 类 添 
加 了 两 个 方法 ， 一 个 是 关 窗 户 的 方法 close_window()， 另 一 个 是 开 窗户 的 方法 open_window()。 使 用 这 
两 个 方法 ， 可 以 改变 窗户 的 开关 状态 。 定 义 完 类 后 ， 为 类 创建 了 一 个 对 象 。 可 以 看 出 通过 两 个 方法 是 
如 何 改变 窗户 的 开关 状态 的 。 

在 类 中 为 类 添加 方法 ， 可 以 使 用 public 默认， 可 以 省 略 ) ~ protected 和 private 关键 字 来 修饰 。 使 
用 public 修饰 的 方法 可 以 在 类 外 部 被 访问 ， 使 用 protected 和 private 修饰 的 方法 则 不 可 在 类 外 部 被 访问 。 

如 果 在 函数 中 要 引用 类 本 身 的 状态 或 者 函数 ， 这 时 必须 使 用 伪 变 量 $this 加 上 引用 的 变量 或 者 函数 


m Lud 
名 ， 才 能 实现 功能 。 这 一 点 需要 引起 读者 的 注意 。 
13.2.4 ”类 的 继承 
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本 节 来 研究 类 的 继承 问题 。 何 为 类 的 继承 呢 ? 

通常 需要 这 样 一些 类 ， 这 些 类 与 其 他 现 有 的 类 拥有 相同 的 变量 和 函数 。 为 了 使 这 一 点 变 得 更 加 容 
易 ， 类 可 以 从 其 他 的 类 中 扩展 出 来 。 扩 展 或 派生 出 来 的 类 拥有 其 基 类 或 者 父 类 的 所 有 变量 和 函数 ， 并 
包含 所 有 派生 类 中 定义 的 部 分 。 类 中 的 元 素 不 可 能 减少 ， 就 是 说 ， 不 可 以 注销 任何 存在 的 函数 或 者 变 
量 。 一 个 扩充 类 总 是 依赖 一 个 单独 的 基 类 ， 也 即 不 支持 多 重 继承 。 

那么 PHP 中 如 何 实现 类 的 继承 呢 ? 在 PHP 中 使 用 如 下 语句 来 实现 对 一 个 类 的 继承 : 

class Son_class extends class 


就 是 在 定义 一 个 子 类 Son class 时 后 面 加 上 extends 再 加 上 父 类 的 名 称 classo 
【实例 13-4】 下 面 把 实例 13-3 中 的 代码 做 一 下 修改 ， 以 便 讲解 如 何 从 一 个 父 类 中 继承 子 类 。 


re 实例 13-4: 如 何 从 一 个 父 类 中 继承 子 类 
_ 源 码 路 径 ; 光盘 \ 源 文件 3\3-4php 00000 


01 <html> 

02 <head> 

03 ”<title> 类 的 继承 使 用 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 class Window /首先 定义 一 个 类 
08 { 

09 public $state; /窗户 的 状态 

10 function close window() /| 关 窗 户 方法 

11 { 

12 $this-»state-"close"; /窗户 的 状态 为 关 
13 y 

14 function open_window() // 开 窗户 方法 

15 { 

16 S$this->state="open"; /窗户 的 状态 为 开 

H 

18 H 

19 class Who Window extends Window /定义 一 个 子 类 继承 父 类 
20 

21 public $owner; /加 入 属性 窗户 的 所 有 人 
22 H 

23 $my. who window-new Who window; /实例 化 一 个 对 象 
24 $my_who_window->owner="Jack"; /定义 窗户 的 所 有 人 
25 echo "my_who_window 的 owner 为 : "; 

26 echo "<p>"; 

27 echo $my who window-»owner; /显示 窗户 的 所 有 人 
28 echo "<p>"; 


soe meone SA 


29 $my_who_window->close_window(); // 调 用 关 窗 户 事件 
30 echo "my who window 的 开关 状态 为 :"; 

31 echo "<p>"; 

32 echo $my_who_window->state; /显示 窗户 开关 状态 
33 ?» 

34 </body> 

35 </html> 


在 PHP 运行 环境 下 执行 该 PHP 文件 ， 执 行 结果 如 图 13.4 所 示 。 


图 13.4 类 的 继承 使 用 实例 执行 结果 


下 面 来 分 析 一 下 代码 。 首 先 定义 了 一 个 父 类 Window， 该 类 有 一 个 $state 属性 与 开 、 关 窗户 两 个 方 
法 。 然 后 又 定义 了 一 个 子 类 Who_Window， 由 于 使 用 了 extends 关键 字 ， 并 且 后 面 跟 上 了 Window 的 类 
名 ， 所 以 该 子 类 继承 自 父 类 Window。 所 以 ，Who_Window 类 就 拥有 父 类 的 全 部 属性 与 方法 ， 并 且 该 
子 类 也 有 自己 的 属性 Sowner， 即 窗户 的 所 有 人 。 

为 类 Who Window 实例 化 了 一 个 对 象 Smy_who_window, 由 于 该 对 象 是 基于 Who. Window 创建 的 ， 
而 Who Window 又 继承 于 父 类 window, IA ZA S 3L BE fi Sstate 属性 也 有 $owner 属性 ， 同 时 也 有 开 、 
关 窗 户 的 两 种 方法 。 

需要 注意 的 是 ,使 用 public 和 protected 修饰 的 属性 和 方法 可 以 被 子 类 继承 ， 而 使 用 private 修饰 的 
属性 和 方法 则 不 可 以 被 子 类 继承 。 


13.2.5 “类 的 重 载 
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一 个 子 类 中 的 属性 或 方法 有 时 会 与 它 所 继承 的 父 类 中 的 属性 或 方法 重 名 , 这 时 就 出 现 了 类 的 重 载 。 

类 的 重 载 实际 上 是 类 属性 以 及 类 的 方法 的 重 载 。 那 么 什么 是 类 的 方法 的 重 载 呢 ? 通 过 前 面 的 介绍 
了 解 到 ， 定 义 一 个 父 类 后 ， 可 以 再 定义 一 个 子 类 对 其 继承 。 这 时 就 存在 一 个 问题 ， 如 果子 类 中 又 定义 
了 和 父 类 中 一 样 的 变量 和 函数 ， 会 出 现 什么 后 果 呢 ? 这 时 ， 如 果 执 行 子 类 的 某 个 方法 ， 还 将 执行 子 类 
中 同名 的 方法 ， 而 并 不 会 影响 父 类 中 相应 的 方法 。 这 一 过 程 就 叫做 类 的 重 载 。 

当然 ， 在 子 类 中 也 可 以 访问 父 类 中 的 方法 ， 不 过 要 使 用 self 和 parent 这 两 个 特殊 的 关键 字 ， 它 们 
是 用 于 在 类 的 内 部 对 成 员 或 方法 进行 访问 的 。 


re 实例 13-5: 如 何 使 用 类 的 重 载 ， 及 如 何在 子 类 中 对 其 父 类 中 的 方法 进行 访问 
源码 路 径 : 光盘 \ 源 文件 \13\13-5.php 


234 
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02 «head» 

O3 ”<title> 类 的 重 载 使 用 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 class Window 

08 $ 

09 public $state; 

10 function close window() 

11 { 

12 S$this->state="close"; 

13 } 

14 function open window() 

15 H 

16 Sthis-»state- "open"; 

17 ) 

18 } 

19 class Who_Window extends Window 
20 ( 

21 public $owner; 

22 function close window() 

23 { 

24 $this-»state-"close"; 

25 S$this-^owner-"Jack"; 

26 ) 

27 function open window() 

28 

29 parent::open window(); 
30 ) 

31 

32 $my who window-new Who window; 
33 $my who window-»close window(); 
34 echo "my who window 的 状态 为 : "; 
35 echo "<p>"; 

36 echo $my who window-»state; 

37 echo "<p>"; 

38 echo "my who window 的 owner Jj: "; 
39 echo "<p>"; 

40 echo $my who window-»owner; 

41 echo "<p>"; 

42 $my who window-»owner-'Li"; 

43 $my who window-»open window(); 
44 echo "my who window 的 状态 为 : "; 
45 echo "<p>"; 

46 echo $my_who_window->state; 

47 echo "<p>"; 

48 echo "my_who_window 的 owner 为 : "; 
49 echo "<p>"; 

50 echo $my who window-»owner; 

51 ?> 

52 </body> 


// 首 先 定义 一 个 类 


/窗户 的 状态 
// 关 窗户 方法 


// 窗 户 的 状态 为 关 
// 开 窗户 方法 
// 窗 户 的 状态 为 开 


// 创 建 一 个 子 类 


/加 入 属性 
// 访 法 的 重 载 


/此 处 改变 窗户 的 状态 
/此 处 改变 窗户 的 所 有 者 


/方法 重 载 
/| 执行 父 类 的 方法 ， 并 不 改变 所 有 者 


// 创 建 一 个 基于 子 类 的 对 象 
// 调 用 关 窗户 事件 


/窗户 状态 此 时 为 关 


/窗户 的 所 有 者 现在 为 jack 


/改变 窗户 所 有 者 


// 调 用 开 窗 户 事件 


// 显 示 状 态 


/显示 所 有 者 


soe meone SA 


53 </html> 


在 PHP 运行 环境 下 执行 该 PHP 文件 ， 执 行 结果 如 图 13.5 所 示 。 


my_who_window 的 状态 为 。 
open 
my_who_window 的 owner 为 : 
li 


NES 
图 13.5 类 的 重 载 使 用 实例 执行 结果 
以 上 实例 中 的 子 类 含有 和 父 类 中 同名 的 方法 ， 即 进行 了 重 载 。 其 中 的 close_window() 方 法 ,不仅 把 
窗户 开关 状态 设置 为 关 , 而 且 还 把 窗户 的 主人 设置 为 Jack。 而 open_window() 方 法 只 是 执行 父 类 中 的 方 
法 改变 窗户 的 开关 状态 ， 并 没有 改变 窗户 的 所 有 人 。 从 这 里 也 可 以 看 到 在 子 类 中 引用 父 类 方法 的 使 用 
模式 :使 用 parent 关键 字 ， 后 面 加 上 “::” 符 号 ， 然 后 在 后 面 加 上 方法 名 。 即 像 下 面 这 样 的 语法 : 
parent::method name() 


从 以 上 实例 及 执行 结果 中 可 以 了 解 到 方法 的 重 载 是 如 何 使 用 的 。 
13.26 ”类 的 引用 
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在 一 个 类 中 使 用 了 其 他 类 的 属性 或 方法 就 称 为 类 的 引用 。 虽 然 这 在 理论 上 是 可 行 的 ， 但 不 推荐 这 
么 做 。 因 为 使 用 类 的 目的 就 是 把 一 类 有 共同 属性 的 东西 封装 起 来 ， 如 果 在 这 些 有 共同 属性 的 东西 中 再 
引用 其 他 类 的 内 容 就 不 符合 面向 对 象 编程 的 初衷 。 不 过 有 关联 的 类 与 类 之 间 还 是 可 以 互相 引用 的 ， 关 
键 看 这 些 类 的 关系 。 

【实例 13-6】 以 下 代码 演示 如 何 实现 类 的 引用 。 


re 实例 13-6: 如 何 实现 类 的 引用 
源码 路 径 : 光盘 \ 源 文件 \13\13-6.php 


02 <head> 

03 ”<title> 类 的 引用 使 用 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 class A ERA 


t 
09 function a method() /创建 方法 
10 ( 
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11 echo "I'm classA's method!"; // 输 出 相应 内 容 
12 ) 

13 ) 

14 class B /创建 类 B 


{ 
16 function b method() /| 创建 方法 


d 
18 echo "I'm classB's method!<br />"; /输出 相应 内 容 
19 A::A_method(); 1/ 引用 类 A 中 的 方法 
20 } 


} 
22 $my_b=new B; NAX B 实例 化 一 个 对 象 
23 $my b-»b method(); // 调 用 对 象 的 方法 
24 ?> 
25 </body> 
26 </html> 


在 PHP 运行 环境 下 执行 该 PHP 文件 ， 执 行 结果 如 图 13.6 所 示 。 


Tm classB' method! 
Tm classA's method! 


图 13.6 类 的 引用 使 用 实例 执行 结果 
通过 以 上 实例 及 执行 结果 可 以 看 出 ， 在 一 个 类 中 是 可 以 引用 另外 一 个 类 的 方法 的 。 使 用 如 下 语法 : 
class name::method name; 
即 类 名 加 上 双 冒 号 再 加 上 方法 名 。 可 以 发 现 ， 这 与 在 子 类 中 引用 父 类 的 方法 有 相似 之 处 。 在 子 类 
中 引用 文 类 不 需要 使 用 类 名 ， 只 用 parent 关键 字 代替 父 类 的 类 名 即 可 。 


13.2.7 ”类 的 构造 函数 
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构造 函数 是 类 中 的 一 种 特殊 函数 ， 当 使 用 new 操作 符 创建 一 个 类 的 实例 时 ， 构 造 函数 将 会 自动 调 
JH. PHP 3.0 和 PHP 4.0 中 ， 当 函数 与 类 同名 时 ， 这 个 函数 将 成 为 构造 函数 。 而 在 PHP 5 中 ， 虽 然 支持 
PHP 3.0 和 PHP 4.0 中 的 用 法 , 但 是 推荐 使 用 _construct0 作 为 类 的 构造 函数 , 这 样 做 的 好 处 是 构造 方法 
无 需 随 着 类 名 的 改变 而 做 修改 。 构 造 函 数 就 是 当 对 象 被 创建 时 类 中 被 自动 调用 的 函数 。 

【实例 13-7】 以 下 代码 演示 在 PHP 中 如 何 创建 并 使 用 构造 函数 。 


re 实例 13-7. 在 PHP 中 如 何 创建 并 使 用 构造 函数 
源码 路 径 : 光盘 \ 源 文件 \13\13-7.php 


02 <head> 
03 ”<title> 类 的 构造 函数 使 用 实例 </titie> 
04 </head> 
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05 <body> 

06 <?php 

07 class Window // 首 先 定义 一 个 类 
08 

09 function — construct() 

10 { 

11 S$this-»close window(); 

12 ) 

13 public $state; /窗户 的 状态 

14 function close window() /| 关 窗 户 方法 

15 { 

16 Sthis-»state-"close"; // 窗 户 的 状态 为 关 
"a n 

18 function open window() // 开 窗户 方法 

19 { 

20 S$this->state="open"; // 窗 户 的 状态 为 开 
21 } 

pp) H 

23 $my windowznew Window; 

24 echo "my window 的 开关 状 为 :"; 

25 echo "<p>"; 

26 echo $my window-»state; 

PX We» 

28 </body> 

29 </html> 


在 PHP 运行 环境 下 执行 该 PHP 文件 ， 执 行 结果 如 图 13.7 所 示 。 


z 


图 13.7 类 的 构造 函数 使 用 实例 执行 结果 
为 什么 窗户 的 状态 会 是 关闭 的 ?因为 在 创建 对 象 时 调用 了 类 的 构造 函数 。 在 以 上 实例 中 ， 构 造 函 
数 的 内 容 是 什么 呢 ? 是 调用 本 类 的 close_window() 方 法 。 由 于 创建 对 象 时 调用 了 构造 函数 ， 而 构造 函数 
又 调用 了 close_window() 方 法 ,也 就 是 说 ,在 创建 对 象 时 就 把 窗户 的 开关 状态 设置 为 关 了 ， 所 以 才 会 出 
现 如 图 13.7 所 示 的 执行 结果 。 
注意 : 如 果 构 造 函 数 带 有 参数 ， 那 么 在 为 类 创建 对 象 时 也 需要 带 上 参数 。 否 则 ， 就 会 有 “缺少 参数 ” 
的 出 错 提 示 。 


【实例 13-8】 以 下 代码 演示 带 有 参数 的 构造 函数 的 创建 及 使 用 方法 。 


re 实例 13-8: 带 有 参数 的 构造 函数 的 创建 及 使 用 方法 
源码 路 径 光盘 \ 源 文件 \13\13-8.php 


01 «html» 
02 <head> 


M aaa 


03 ”<title> 构 造 函 数 的 参数 使 用 实例 </title> 


04 </head> 

05 <body> 

06 <?php 

07 class Temp // 首 先 定义 一 个 类 
08 { 

09 function — construct($str) 

10 { 

11 echo $str; 

12 ) 

13 ) 

14 $my tempznew Temp("hello world!"); 
15 ?> 

16 </body> 

17 </html> 


在 PHP 运行 环境 中 执行 该 PHP 文件 ， 将 会 输出 “hello world!” 字 样 。 这 是 因为 类 Temp 的 构造 函 


数 的 作用 是 将 参数 的 内 容 输出 。 
133 PHP 中 与 类 、 对 象 相关 的 函数 
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PHP 中 提供 了 函数 来 实现 对 类 的 相关 操作 。 本 节 就 介绍 PHP 中 与 类 相关 的 常用 函数 。 


1. class_exists() 函 数 
class_exists() 函 数 的 格式 如 下 : 
bool class exists(string class name[,bool autoload]) 


该 函数 检查 类 是 否 已 定义 ， 如 果 由 字符 串 变量 clas name 所 指 的 类 已 经 定义 ， 此 函数 返回 True, 


和 否则 返回 False. 


在 进行 PHP 编程 时 判断 一 个 类 是 否 被 定义 是 很 有 必要 的 ， 如 果 类 已 经 被 定义 就 可 以 为 该 类 创建 一 


个 对 象 。 但 如 果 类 不 存在 ， 也 就 无 法 创建 对 象 。 
【实例 13-9】 以 下 代码 演示 如 何 使 用 class_exists0 函 数 来 判断 类 是 否 被 定义 。 


TE | 实例 13.9， 如 何 使 用 class_exists() 函 数 来 判断 类 是 否 被 定义 


源码 路 径 : 光盘 \ 源 文件 \13\13-9.php 


02 <head> 

03 ”<title>class_exists() 函 数 使 用 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 class Window // 首 先 定义 一 个 类 


t 
09 public $state; /窗户 的 状态 


10 function close window() 
ag { 

12 Sthis-»state-"close"; 
13 l 

14 function open window() 
15 { 

16 S$this->state="open"; 
17 H 

18 } 

19 class Who_Window extends Window 
20 { 

21 public $owner; 

22 function close window() 
23 { 

24 $this->state="close"; 
25 S$this->owner="Jack"; 
26 } 

27 } 

28 function f_e($string) 

29 

30 if(class_exists($string)) 
31 echo "名 为 ".$string." 的 类 已 经 存在 ! "s 
32 else 

33 echo "名 为 ".$string." 的 类 并 不 存在 ! "; 
34 ) 

35 f e("Window"); 

36 echo "<p>"; 

37 f e("Who Window"); 

38 echo "<p>"; 

39 f e('temp class"); 

40 echo "<p>"; 

4 7? 

42 </body> 

43 «html» 
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// 关 窗户 方法 
// 窗 户 的 状态 为 关 
// 开 窗户 方法 


// 窗 户 的 状态 为 开 


/创建 子 类 


/方法 继承 


/创建 一 个 基于 class_exists() 的 自 定义 函数 
// 如 果 类 名 存在 

// 打 印 相应 信息 

// 如 果 类 不 存在 

// 打 印 相应 信息 

// 调 用 函数 

// 调 用 函数 


// 调 用 函数 


TE PHP 运行 环境 中 执行 该 PHP 文件 ， 执 行 结果 如 图 13.8 所 示 。 


E hapjllocalhosjlsP ~ C 


| 名 为 Window 的 类 已 
名 为 Wk 
名 为 kmp_cass 的 类 并 不 存 丰 


图 13.8 


Vindow 的 类 已 经 存在 


A100 ”> 


al 


class_exists() 函 数 使 用 实例 执行 结果 


通过 以 上 实例 及 执行 结果 可 了 解 , 用 class_exists() 函 数 来 判断 类 是 否 被 定义 是 很 方便 的 , 而 且 该 函 


数 使 用 起 来 也 很 简单 ， 这 里 不 做 过 多 解释 。 


2. get_class_methods() 函 数 
get_class_methods() 函 数 的 格式 如 下 : 


NK 
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array get_class_methods(mixed class_name) 


该 函数 返回 由 类 的 方法 名 组 成 的 数组 。 调用 该 函数 , 将 返回 名 称 为 class_name 的 类 的 全 部 方法 名 。 
通过 此 函数 就 能 了 解 某 一 个 类 的 方法 的 情况 。 
了 解 一 个 类 的 方法 名 的 详细 情况 也 是 很 有 必要 的 。 知 道 类 的 方法 名 后 ， 就 可 以 对 其 进行 引用 。 
【实例 13-10】 以 下 代码 演示 如 何 使 用 get_class_methods0 〇 函数 来 获得 类 的 全 部 方法 名 。 


re 实例 13-10: 如 何 使 用 get_class_methods() 函 数 来 获得 类 的 全 部 方法 名 
源码 路 径 : 光盘 \ 源 文件 \13\13-10.php 


01 <html> 

02 <head> 

03 ”<title>get_class_methods() 函 数 使 用 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 class Window // 首 先 定义 一 个 类 
08 { 

09 public $state; APRIRE 

10 function close_window() /| 关 窗 户 方法 

11 { 

12 Sthis-»state-"close"; III PA RAS Z0 
13 l 

14 function open window() // 开 窗户 方法 

15 { 

16 $this->state="open"; III PARS AS E 
17 } 

18 } 

19 $temp=get_class_methods("Window"); 

20 echo "类 Window 中 的 方法 有 以 下 几 个 : "; 

21 echo "<p>"; 

22; for($i=0;$i<count($temp);$i++) 

23 echo $temp[$i].", "; 

ug 

25 </body> 

26 </html> 


在 PHP 运行 环境 下 执行 该 PHP 文件 ， 执 行 结果 如 图 13.9 所 示 。 
r 


alheat/i P ~ 


| 类 Wandow 中 的 方法 有 以 下 几 个， 


close window, open window, 


图 13.9 get_class_methods() 函 数 使 用 实例 执行 结果 
3. get_class_vars() 函 数 
get_class_vars() 函 数 的 格式 如 下 : 


array get class vars(string class name) 


e. 


soe meone SA 


调用 该 函数 将 会 返回 由 类 的 默认 公有 属性 组 成 的 关联 数组 ， 此 数组 的 元 素 以 vamame=>value 的 形 
式 存 在 。 
在 使 用 一 个 类 并 为 其 定义 对 象 之 前 也 有 必要 了 解 类 中 变量 的 情况 。 
【实例 13-11】 以 下 代码 演示 如 何 使 用 该 函数 来 获取 相应 的 内 容 。 


re 实例 13-11: 如 何 使 用 get_class_vars0 函 数 来 获取 相应 的 内 容 
源码 路 径 光盘 \ 源 文件 \13\13-11.php 


01 «html» 

02 «head» 

O3 ”<title>get_class_vars() 函 数 使 用 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 class Dog // 首 先 定义 一 个 类 


{ 
09 public $name; // 狗 的 名 字 
10 public $age; // 狗 的 年 龄 
11 public $birthday-"3/15"; // 狗 的 生日 
12 public $sex="male"; // 狗 的 性 别 
13 } 
14 S$temp=array_keys(get_class_vars("Dog")); // 调 用 get_class_vars() 函 数 
15 echo "类 Dog 的 属性 有 以 下 几 个 : "; 
16 echo "<p>"; 
(i print r($temp); 


在 PHP 运行 环境 中 执行 该 PHP 文件 ， 执 行 结果 如 图 13.10 所 示 。 
[3151757] 


[€] Qi ipi ecalbow1: O ~ È || GB qet class varst 
类 Dog 的 属性 有 以 下 几 个 ， 


Array ( [0] => name [1] — age [2] = birthday [3] => sex ) 


A109 v 


图 13.10 ”get_class_vars() 函 数 使 用 实例 执行 结果 

4. get_class() 函 数 

get_class0 函 数 的 格式 如 下 : 

string get class([object obj]) 

调用 该 函数 将 会 返回 对 象 实例 obj 所 属 类 的 名 字 。 如 果 obj 不 是 一 个 对 象 则 返回 False. 

对 象 都 是 基于 类 创建 的 ， 一 般 情 况 下 ， 知 道 了 对 象 名 就 知道 相应 的 类 名 。 但 是 如 果 对 象 特别 多 ， 
可 以 使 用 该 函数 来 确定 对 象 所 属 的 类 。 
注意 : 使 用 该 函数 时 ， 在 PHP 扩 展 库 中 定义 的 类 返回 其 原始 定义 的 名 字 。 在 PHP 4.0 中 ，get_class() 函 数 

返回 用 户 定义 的 类 名 的 小 写 形式 , 但 是 在 PHP 5 中 将 返回 类 名 定义 时 的 名 字 , 如 同 扩展 库 中 的 类 


KJ 
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名 一 样 。 自 PHP 5 起 ， 如 果 在 对 象 的 方法 中 调用 则 obj 为 可 选项 。 
【实例 13-12】 以 下 代码 演示 get_class0O) 函 数 的 使 用 方法 。 


N o 实例 13-12，get_class0 函 数 的 使 有 方法 
源码 路 径 光盘 \ 源 文件 \13\13-12.php 


01 «html» 

02 <head> 

03 <title>get class () 函 数 使 用 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 class Dog /首先 定义 一 个 类 
08 ft 

09 public $name; // 狗 的 名 字 

10 public $age; // 狗 的 年 龄 

11 public $birthday; // 狗 的 生日 

12 public $sex; // 狗 的 性 别 

13 } 

14 $mydog=new Dog; /实例 化 一 个 对 象 
15 $mydog->name-"wang"; /定义 名 字 

16 $mydog->age="two month"; /定义 年 龄 

17 $mydog-»birthday-"3/15"; // 定 义 生日 

18 $mydog->sex="male"; /定义 性 别 

19 echo "对 象 mydog 所 属 的 类 为 :"; 

20 echo get_class($mydog); // 调 用 函数 输出 对 象 所 属 的 类 
wA 2> 

22 </body> 

23 </html> 

在 PHP 运行 环境 中 执行 该 PHP 文件 ， 执 行 结果 如 图 13.11 所 示 。 


o (B htpy/lccalhosy13 £ 


对 象 mydog 所 展 的 类 为 ， Dog | 
*1006 v 


图 13.11. get_class() 函 数 使 用 实例 执行 结果 
通过 以 上 实例 及 执行 结果 可 以 看 出 ， 调 用 get_class0) 函 数 ， 返 回 了 对 象 Smydog 所 属 的 类 Dog, JA 
而 说 明 函 数 正 确 运行 。 
5. get_declared_classes() 函 数 
get_declared_classes() 函 数 的 格式 如 下 : 
array get declared classes() 


调用 该 函数 将 会 返回 由 当前 脚本 中 已 定义 类 的 名 字 组 成 的 数组 。 
由 于 PHP 中 有 预定 义 类 ， 即 系统 自动 生成 的 类 ， 所 以 使 用 该 函数 ， 将 会 有 以 下 儿 个 预定 义 类 存在 
于 返回 的 数组 中 : stdClass、OverloadedTestClass、Directory。 同 时 ， 由 于 有 这 些 预定 义 类 的 存在 ， 在 创 
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建 类 时 不 能 使 用 这 些 预 定义 类 名 作为 类 的 名 称 。 
【实例 13-13】 以 下 代码 演示 get_declared_classes() 函 数 的 使 用 方法 。 


实例 13-13: get_declared_classes() 函 数 的 使 用 方法 
源码 路 径 : 光盘 \ 源 文件 \13\13-13.php 


02 <head> 

03 ”<title>get_declared_classes() 函 数 使 用 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 class Dog /定义 一 个 类 Dog 

08 

09 public $name; // 狗 的 名 字 

10 public $age; // 狗 的 年 龄 

11 public $birthday; // 狗 的 生日 

12 public $sex; // 狗 的 性 别 

13 H 

14 class Window /定义 一 个 类 Window 
15 { 

16 public $state; /窗户 的 状态 

17 function close window() // 关 窗户 方法 

18 i 

19 Sthis-»state-"close"; // 窗 户 的 状态 为 关 

20 } 

21 function open window() // 开 窗户 方法 

22 je 

23 $this->state="open"; // 窗 户 的 状态 为 开 

24 } 

25 H 

26 class Who Window extends Window /创建 Window 的 子 类 Who Window 
27 { 

28 public $owner; 

29 function close window() /方法 继承 

30 { 

31 Sthis-»state-"close"; 

32 Sthis-»owner-"Jack"; 

33 } 

34 } 

35 /至 此 ， 此 PHP 文件 中 一 共 定义 有 3 个 类 ， 分 别 是 Dog. Window, Who Window. 
36 现在 调用 get_declared_classes() 函 数 ， 看 能 否 正确 返回 */ 

37 $temp-get declared classes(); // 调 用 函数 ， 把 结果 保存 到 变量 中 
38 for($i=0;$i<count($temp);$i++) // 通 过 循环 显示 数组 所 有 元 素 
39 f 

40 echo "数组 的 第 ".$i." 个 元 素 为 : "5 

41 echo $temp[$i]; 

42 echo "<p>"; 

43 H 

44 ?> 


M ea 


45 </body> 
46 </html> 


在 PHP 运行 环境 中 执行 该 PHP 文件 ， 执 行 结果 如 图 13.12 所 示 。 


BEER DA TUER 


数组 的 第 123 个 元 素 为 ， mysqli_smr 
数组 的 第 124 个 元 素 为 ， Dog 

堵 组 的 第 125 个 元 素 为 ，Window 
BERME NATRA: Who Window ~ 


图 13.12. get_declared_classes() 函 数 使 用 实例 执行 结果 

从 图 13.12 可 以 看 出 ， 由 于 有 预定 义 类 的 存在 ， 所 以 函数 首先 返回 预定 义 类 , 然后 才 返 回 3 个 用 户 
自 定义 类 : Dog. Window 和 Who_Window。 

6. get_object_vars() 函 数 

get_object_vars( 〇 函数 的 格式 如 下 : 

array get_object_vars(object obj) 

该 函数 返回 由 对 象 属性 组 成 的 关联 数组 。 
注意 : 在 PHP 4.2.0 之 前 的 版 本 中 ， 如 果 在 obj 对 象 实例 中 声明 的 变量 没有 被 赋值 ， 则 它们 将 不 会 在 返回 

的 数组 中 ， 而 在 PHP 4.2.0 以 后 的 版 本 中 ， 这些 变 量 作 为 键 名 被 赋予 NULL 值 。 


【实例 13-14】 以 下 代码 演示 get_object_vars() 函 数 是 如 何 获得 对 象 属性 的 。 
Eog 实例 13-14: get_object_vars0 函 数 是 如 何 获得 对 象 属性 的 
源码 路 径 ， 光盘 \ 源 文件 \13\13-14.php 


01 <html> 

02 <head> 

03 ”<title>get_object_vars() 函 数 使 用 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 class Dog // 首 先 定义 一 个 类 
08 { 

09 public $name; // 狗 的 名 字 

10 public $age; // 狗 的 年 龄 

11 public $birthday; / 狗 的 生日 

12 public $sex; // 狗 的 性 别 

13 } 

14 $mydog-new Dog; /实例 化 一 个 对 象 
15 $mydog->name-"wang"; /定义 名 字 

16 $mydog-»age-"two month"; /定义 年 龄 

17 $mydog-»birthday-"3/15"; /定义 生日 
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18 $mydog-»sex-"male"; /定义 性 别 

19 $temp-get object vars($mydog); // 调 用 函数 把 对 象 的 属性 赋值 给 数组 
20 print r($temp); 

21. 

22 </body> 

23 </html> 


在 PHP 运行 环境 下 执行 该 PHP 文件 ， 执 行 结果 如 图 13.13 所 示 。 


ij 


o le kipi omo P » Č | B aec object var. 
| Array ( [name] => wang [age] 一 two month [birthday] — 3/15 [sex] => male) 
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图 13.13 ”get_object_vars() 函 数 使 用 实例 执行 结果 
从 图 13.13 所 示 的 执行 结果 中 可 以 看 出 ， 函 数 返回 了 对 象 mydog 的 所 有 属性 及 值 ， 说 明 
get object vars() FK ZI IE fie fT o 
7. get parent class()EZ&t 
get_parent_class() 函 数 的 格式 如 下 : 
string get parent class([mixed obj]) 


该 函数 返回 对 象 或 类 的 父 类 名 。 如 果 obj 是 对 象 ， 则 返回 对 象 实例 obj 所 属 类 的 父 类 名 ; 如 果 obj 
是 字符 串 ， 则 返回 以 此 字符 串 为 名 的 类 的 父 类 名 。 此 功能 是 在 PHP 4.0.5 中 增加 的 。 自 PHP 5 起 ， 如 果 
在 对 象 的 方法 内 调用 ， 则 obj 为 可 选项 。 


01 «html» 

02 «head» 

03 ”<title>get_parent_class() 函 数 使 用 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 class Window /定义 一 个 类 Window 
08 { 

09 public $state; /窗户 的 状态 

10 function close window() /| 关 窗 户 方法 

11 4 

12 $this-»state-"close"; II PA BAS Z0 

13 } 

14 function open_window() // 开 窗户 方法 

15 { 

16 $this->state="open"; /窗户 的 状态 为 开 

AT } 

18 } 

19 class Who_Window extends Window /创建 Window 的 子 类 Who Window 


© 


KA aaa 


20 ( 

zi public $owner; 

22 function close window() 

23 { 

24 $this-»state-"close"; 

25 Sthis-»owner-"Jack"; 

26 H 

27 

28 $my who window-new Who Window; 

29 $temp1-get parent class("Who Window"); 
30 $temp2-get parent class($my who window); 
31 echo "类 Who Window 的 父 类 为 :"; 

32 echo "<p>"; 

33 echo $temp1; 

34 echo "«p»"; 

35 echo "对 象 my who window 所 属 类 的 父 类 为 :"; 
36 echo "<p>"; 

37 echo $temp2; 

38 ?> 

39 </body> 

40 </html> 


/方法 继承 


/实例 化 一 个 对 象 
// 调 用 get_parent_class() 函 数 把 结果 赋值 给 变量 
// 调 用 get_parent_class() 函 数 把 结果 赋值 给 变量 


// 输 出 结果 


// 输 出 结果 


在 PHP 运行 环境 中 执行 该 PHP 文件 ， 其 执行 结果 如 图 13.14 所 示 。 


【实例 13-16】 以 下 代码 演示 如 何 使 月 


cjus 


S ilfocihos1: D > © 


| 类 Whe_Window 的 父 类 为 ， 
Window 


对 象 my_wao_window 订 属 夫 的 父 类 为 : 


Window 


*ix* ~ 


图 13.14 ”get_parent_class() 函 数 使 用 实例 执行 结果 

通过 以 上 实例 可 以 看 出 , 第 一 次 调用 get_parent_class() 函 数 时 使 用 的 参数 是 字符 串 , 即 子 类 的 名 称 ， 
函数 能 正确 返回 父 类 的 名 称 ， 第 二 次 调用 时 使 用 的 参数 是 对 象 名 ,函数 返回 了 对 象 bmy_who_window 
所 属 的 类 Who Window 的 父 类 Window。 通 过 两 次 调用 可 以 看 出 ，get_parent_class() 函 数 不 仅 能 返回 子 
类 的 父 类 名 称 ， 也 能 返回 对 象 所 属 子 类 的 父 类 。 

8. is_subclass_of() 函 数 

is_subclass_ofO 函 数 的 格式 如 下 : 

boolis subclass of(object object,string class name) 

如 果 对 象 object 所 属 类 是 类 class name 的 子 类 ， 则 该 函数 返回 True， 和 否则 返回 False。 此 函数 的 目 
的 就 是 判断 某 个 对 象 是 否 属 于 某 个 类 或 者 是 其 父 类 。 


源码 路 径 光盘 \ 源 文件 \13\13-16.php 


日 is_subclass_ofO) 函 数 来 进行 对 象 与 类 的 关系 的 判断 。 


D 3-16: 演示 如 何 使 用 is_subclass_of() 函 数 来 进行 对 象 与 类 的 关系 的 判断 


«html» 
<head> 
<title>is_subclass_of() 函 数 使 用 实例 </title> 
</head> 
<body> 
<?php 
class Window 
{ 
public $state; 
function close window() 
{ 
$this->state="close"; 


n 
function open window() 
{ 

Sthis->state="open"; 
} 


} 
class Who_Window extends Window 
{ 
public $owner; 
function close window() 
i 
$this-»state-"close"; 
$this-»ownerz"Jack"; 
) 
H 
function is sub e($0bj,$string) 


t 
ifis subclass of(Sobj,$string)) 
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/首先 定义 一 个 类 


/窗户 的 状态 
// 关 窗户 方法 


// 窗 户 的 状态 为 关 
// 开 窗户 方法 
// 窗 户 的 状态 为 开 


/创建 Window 的 子 类 Who Window 


/方法 继承 


/创建 一 个 基于 is_subclass_of() 的 自 定义 函数 


// 如 果 类 名 存在 


echo "对 象 属于 名 为 ".$string." 的 类 的 子 类 的 对 象 !"，// 打 印 相 应 信息 


} 


else 


// 如 果 类 不 存在 


echo "对 象 不 属于 名 为 ".$string." 的 类 的 子 类 的 对 象 ! "// 打 印 相应 信息 


D 
) 
class Dog 
t 

public $name; 

public $age; 

public Sbirthday; 

public $sex; 
} 
$my_window=new Who_Window; 
is sub e($my window,"Who Window"); 
echo "<p>"; 
is sub e($my window," Window"); 
echo "<p>"; 


/首先 定义 一 个 类 
// 狗 的 名 字 
// 狗 的 年 龄 
// 狗 的 生日 
// 狗 的 性 别 
// 调 用 自 定义 函数 


// 调 用 自 定义 函数 


E: 
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51 is sub e($my window,"Dog"); // 调 用 自 定 义 函 数 
52 ?> 
53 </body> 
54 </html> 
在 PHP 运行 环境 中 执行 该 PHP 文件 ， 执 行 结果 如 图 13.15 所 示 。 
peer 


Qoi: oo 
对 象 不 属于 名 为 Who Window 的 类 的 子 类 的 对 象 ! 
对 象 属于 名 为 Window 的 类 化 子 类 的 对 象 

对 象 不 属 丁 名 为 Dog 的 类 的 子 类 的 对 象 ! 


R100% ~ 


图 13.15 ”is_subclass_oft) 函 数 使 用 实例 执行 结果 

从 图 13.15 可 以 看 出 ， 由 于 对 象 my. window 是 基于 类 Who Window 建立 的 ， 而 类 Who Window 
又 是 类 Window 的 子 类 , 所 以 执行 is_subclass_of0) 函 数 ， 在 列 出 的 3 个 类 中 只 有 Window 类 是 符合 条 件 
的 。 所 以 图 13.15 中 只 有 第 二 次 输出 了 “属于 ”的 信息 ， 其 他 两 次 都 输出 “不 属于 ”的 信息 。 

9. method_exists() 函 数 

method_exists0O) 函 数 的 格式 如 下 : 

bool method exists(object object,string method name) 

该 函数 检查 object 类 的 method_name() 方 法 是 否 存在 。 如 果 存 在 , 函数 返回 True, 反之 则 返回 False. 

【实例 13-17】 以 下 代码 演示 method_exists() 函 数 是 如 何 对 对 象 的 方法 进行 操作 的 。 


01 <html> 

02 <head> 

03 ”<title>method_exists() 函 数 使 用 实例 </title> 

04 </head> 

05 <body> 

06 <?php 

07 class Window [I9 3 
08 { 

09 public $state; /窗户 的 状态 

10 function close window() /| 关 窗 户 方法 

11 { 

12 $this->state="close"; /窗户 的 状态 为 关 
13 ji 

14 function open window() // 开 窗户 方法 

15 { 

16 Sthis-^state-"open"; /窗户 的 状态 为 开 
} 

18 } 

19 function method e($0bj,$string) /创建 一 个 基于 method_exists() 的 自 定义 函数 
20 { 
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21 if(method exists(Sobj,Sstring)) // 如 果 类 名 存在 
22 { 

23 echo "对 象 中 名 为 ".$string." 的 类 已 经 存在 ! "; /打印 相应 信息 
24 } 

25 else // 如 果 类 名 不 存在 
26 { 

27 echo "对 象 中 名 为 ".$string." 的 类 并 不 存在 !"; // 打 印 相 应 信息 
28 H 

29 H 

30 $my window-new Window; 

31 method e($my window,"open window"); // 调 用 自 定 义 函 数 
32 echo "<p>"; 

33 method e($my window,"close window"); // 调 用 自 定 义 函 数 
34 echo "<p>"; 

35 method e($my window,"temp method"); /调用 自 定 义 函 数 
36 ?> 

37 </body> 

38 </html> 


在 PHP 运行 环境 下 执行 该 PHP 文件 ， 执 行 结果 如 图 13.16 所 示 。 


图 13.16 


lole me 
EP 
对 象 中 名 为 opca_window 的 类 已 经 存在 ! 
对 象 中 名 为 close_window 的 类 已 经 存在 ! 
对 象 中 名 为 temp_method 的 类 并 不 存在 ! 


^i» ~ 


method_exists0) 函 数 使 用 实例 执行 结果 


从 图 13.16 可 以 看 出 ， 通 过 调用 基于 method_exists() 函 数 的 自 定义 函数 ， 正 确 地 对 对 和 象 中 的 方法 情 
况 进行 了 判断 。 以 上 实例 中 ， 由 于 open_window() 与 close_window() 方 法 均 已 经 存在 ， 所 以 返回 方法 存 
在 的 信息 ， 而 temp method 不 存在 ， 所 以 返回 方法 不 存在 的 信息 。 


13.4 


类 的 具体 使 用 实例 


CI 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 13 章 \ 类 的 具体 使 用 实例 .wmv 
本 节 将 综合 前 面 几 节 所 学 习 的 内 容 ， 通 过 一 个 实例 来 实际 应 用 学 到 的 知识 。 
【实例 13-18】 以 下 代码 是 用 PHP 面向 对 象 的 特性 写 一 个 完全 的 购物 车 类 。 


而 向 对 象 的 特性 写 一 个 完全 的 购物 车 类 


区 实例 13-18: Hi PHP ji 
源码 路 径 光盘 \ 源 文件 \13\13-18.php 


02 <head> 

03 ”<title> 面 向 对 象 的 具体 使 用 一 一 购 
04 </head> 

05 <body> 


物 车 类 </title> 


— 


PHP 网 络 编程 技术 详解 
06 <?php 
class ShopCar /类 名 购物 车 类 
t 
public $carName; // 属 性 购物 车 名 字 
public $debug; /属性 
function — construct($carName) /创建 购物 车 方法 〈 构 造 函数 ) 
t 
$this-»carName-$carName; /将 购物 车 命名 为 指定 名 称 
if(lisset($_SESSION[$carName])) /如 果 没 有 保存 为 session 
$ SESSION[$carNameJ-array(); /把 购物 车 名 称 保存 到 session 
y 
function addCar($type, $name, $val) // 向 购物 车 中 增加 商品 方法 
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28 
29 
30 
31 
32 
33 
34 
35 
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if(array key exists($type,?$ SESSION([Sthis-»carName]))//5n RŽ 3l B £f Te. 


t 
if(array key exists($name,$ SESSION[Sthis-»carNamej][Stype]))/5n RE AFE 


{ 
if(Sthis->debug)echo "<p> 已 有 fname} 商 品 ,不 必 增 加 <p>"; /输出 相应 信息 


retur false; /返回 假 
i // 如 果 商 品 不 存在 
$ SESSION[Sthis-»carName][Stype][$name]-Sval; // 在 session 中 设 定 
) 
yA // 如 果 类 别 不 存在 
$_SESSION[$this->carName][$type]=array($name=>$val); 。“// 在 session 中 设 定 
ue true; /返回 真 值 
He editCar($type,$name,S$var) // 编 辑 购物 车 方法 
i if(larray key exists($name,$ SESSION[Sthis-»carName][$type]) /如 果 类 别 不 存在 
if(Sthis-»debug)echo "<p> 没 有 {$name} 商 品 ,修改 失败 <p>"; /输出 错误 信息 
return false; /返回 假 什 
WA ia a aa // 在 session 中 设 定 
return true; 
ANE delCarType(Stype) /删除 购物 车 类 别 
if(larray key exists(Stype,$ SESSION[Sthis-»carName])) // 如 果 类 别 不 存在 
if(Sthis-»debug)echo "<p> 没 有 {$type} 类 别 ,删除 失败 <p>"; // 输 出 错误 信息 
return false; /返回 假 值 
NE REI /在 session 中 删除 
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57 return true; // 返 回 真 值 

58 l 

59 function delCarPro(S$type,$name) /删除 商品 

60 { 

61 if(larray key exists($name,$ SESSION[Sthis-»carName][$type]) ”// 如 果 商 品 不 存在 
62 £ 

63 if($this->debug)echo "<p> 没 有 {$name} 商 品 ,删除 失败 <p>"; 。“”// 输 出 错误 信息 

64 retur false; // 返 回 假 值 

65 } 

66 unset($_SESSION[$this->carName][$type][$name]); NE session 中 删除 
67 return true; // 返 回 真 值 

68 H 

69 function delCar() D TES 

70 { 

71 session unregister(Sthis-»carName); JI session 中 注销 
72 y 

73 function getCarData() // 获 取 购 物 车 数据 
74 ( 

75 return $ SESSION[Sthis-»carName]; [ifi session 返回 
76 ) 

77 H 

78 $my. carznew Shopcar("my. shopcar"); /创建 对 象 时 一 定 要 带 参数 ， 否 则 会 有 出 错 提示 
79 $my_car->addCar(" 水 果 "," 苹 果 ",10); /为 购物 车 添加 商品 
80 $my. car-»addCar(" 7k", & $&",5); 

81 $my. car-»addCar("zk "Ai" 4); 

82 $my car-»addCar(" Ese" " 3E" ,10); 

83 $my_car->addCar(" 蔬 菜 "," 萝 卜 ",3); 

84 $my_car->addCar(" 蔬 菜 "," 菠 菜 ",12); 

85 $my_car->addCar(" 蔬 菜 "," 茄 子 ",8); 

86 $temp-$my car-»getCarData(); 

87 print r (Stemp); 

88 ?> 

89 </body> 

90 </html> 


以 上 实例 创建 了 一 个 功能 完善 的 购物 车 类 ， 既 可 以 单独 使 用 ， 也 可 以 通过 连接 数据 库 ， 形 成 一 个 
功能 强大 的 在 线 购物 平台 。 在 PHP 运行 环境 中 执行 该 PHP 文件 ， 执 行 结 果 如 图 13.17 所 示 。 
[EE 
o E hspy/localhost/1: O ~ (j| B 西向 对 全 的 具体 使 用 


Array ( [水 果 ] => Array ( [单果 ] => 10 [Er] => 5 [9] 一 4 ) [ER] 一 
Aray ( [日 菜 ] 一 10 [F |] 3 B] — 12 [前 子 ] =>8)) 


图 13.17 购物 车 类 执行 结果 
由 图 13.17 可 以 看 到 ， 通 过 addCar() 方 法 向 购物 车 中 添加 了 部 分 商品 ， 又 通过 getCarData() 方 法 获 
取 各 类 商品 的 相关 信息 。 另 外 ， 该 类 中 删除 商品 、 删 除 购物 车 等 方法 也 都 是 非常 有 用 的 ， 有 兴趣 的 读 
者 可 以 继续 完善 上 面 的 代码 ， 以 验证 各 种 方法 的 正确 性 。 


KA aaa 


13.5 A € 小 结 


本 章 主要 带领 读者 学 习 了 PHP 的 面向 对 象 编程 的 特性 ， 学 习 了 什么 是 类 、 什 么 是 对 象 、 如 何 使 用 
类 、PHP 中 与 类 及 对 象 相关 的 函数 等 。 正 如 本 章 开头 所 提 到 的 那样 ， 编 程 语言 的 方法 有 面向 对 象 与 面 
向 过 程 两 种 ， 有 具体 采用 哪 种 方法 ， 完 全 取决 于 用 户 。 但 是 作者 还 是 提议 : 在 写 小 型 程序 ， 代 码 不 多 的 
情况 下 ， 采 用 面向 过 程 的 方法 要 好 一 点 。 同 理 ， 当 开发 大 型 项 目 ， 代 码 动 辑 成 二 上 万 行 时 ， 采 用 面向 
对 象 的 编程 方法 可 以 提高 工作 效率 。 


13.6 本 章 习题 


习题 13-1 定义 human 类 ,该 类 应 该 具有 name、sex 成 员 属 性 以 及 sayhello0 成 员 方 法 ,调用 sayhello0 
方法 会 输出 “Hello! ”字符 串 。 

【分 析 】 该 习题 主要 考查 读者 对 创建 类 的 知识 的 掌握 。 

【关键 代码 】 


class human( 
public $name; 
public $sex; 
public function sayhello()( 
echo 'Hello!': 
H 
) 


习题 13-2 为 习题 13-1 创建 的 human 类 创建 构造 函数 ， 该 构造 函数 用 来 初始 化 成 员 属性 name 和 
sex 的 值 。 
【分 析 】 该 习题 主要 考查 读者 对 构造 函数 的 掌握 。 
【关键 代码 】 
public function — construct($name,$sex)( 
$this-»name-$name; 
Sthis-»sex-$sex; 


) 


习题 13-3 ”实例 化 习题 13-2 中 创建 的 human 类 的 一 个 对 象 , 并 输出 该 对 象 的 name 以 及 调用 该 对 
象 的 sayhello() 成 员 方法 。 
【分 析 】 该 习题 主要 考查 读者 对 对 象 的 属性 和 方法 的 访问 。 
【关键 代码 】 
$human1=new human('Tom','boy'); 


echo $human1-»name; 
Shuman1-»sayhello(); 


@ 
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习题 13-4 创建 一 个 继承 自 human 类 的 子 类 superman 并 实例 化 该 类 的 一 个 对 象 来 访问 其 成 员 方 
法 sayhello(). 

【分 析 】 该 习题 主要 考查 读者 对 类 的 继承 的 掌握 。 

【关键 代码 】 


class superman extends human( 


} 
$human1=new superman('Tom','boy'); 
$human1->sayhello(); 


习题 13-5 ”在 习题 13-4 的 基础 上 将 父 类 的 成 员 方法 sayhello0) 重 载 为 输出 “What's your name?” , 
并 且 实 例 化 一 个 对 象 来 调用 该 方法 。 
【分 析 】 该 习题 考查 读者 对 类 的 重 载 的 理解 。 


class superman extends human( 
public function sayhello()( 
echo "What's your name?"; 
H 
l 
$human1=new superman('Tom','boy"); 
Shuman1-»sayhello(); 


第 14 章 ”使 用 MuySQL 数据 库 


只 有 与 数据 库 相 结合 ， 才 能 发 挥动 态 网 页 编程 语言 的 魅力 。 因 为 网 上 的 众多 应 用 都 是 基于 数据 库 
的 。 虽 然 PHP 支持 多 种 数据 库 ， 但 PHP 与 MySQL 可 称 得 上 是 黄金 组 合 。MySQL 是 一 个 轻型 SQL 数 
据 库 服 务 器 ， 可 运行 在 多 种 平台 上 ， 包 括 Windows NT 和 Linux. MySQL 被 认为 是 建立 数据 库 驱 动 的 
动态 网 站 的 最 佳 产品 。 

本 章 就 带领 读者 学 习 MySQL， 包 括 : 关系 型 数据 库 基础 、PHP 中 与 MySQL 数据 库 相 关 函 数 、 如 
何 创 建 一 个 数据 库 、 如 何在 PHP 文档 中 执行 SQL 语句 、MySQL 的 高 级 查询 等 内 容 。 最 后 还 将 通过 一 
个 实例 一 一 学 生 档 案 管 理 系统 来 巩固 本 章 的 知识 。 通 过 本 章 的 学 习 ， 读 者 能 够 熟练 地 写 出 基于 数据 库 
的 Web 应 用 程序 。 


14.1 关系 型 数据 库 基础 


通常 所 说 的 数据 库 有 两 种 类 型 :一 种 是 以 库 、 表 为 基础 的 关系 型 数据 库 ， 另 一 类 是 用 文本 文件 或 
者 二 进 制 文件 作为 数据 载体 的 文本 型 数据 库 。 本 节 来 介绍 关系 型 数据 库 。 


14.1.1 什么 是 关系 型 数据 库 


F 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 14 章 \ 什 么 是 关系 型 数据 库 .wmv 

关系 型 数据 库 以 行 和 列 的 形式 存储 数据 ， 以 便于 用 户 理解 。 这 一 系列 的 行 和 列 被 称 为 表 ， 一 组 表 
组 成 了 数据 库 。 用 户 用 查询 〈Query) 来 检索 数据 库 中 的 数据 。 一 个 Query 是 一 个 用 于 指定 数据 库 中 行 
和 列 的 SELECT 语句 。 

关系 型 表 (Table) 是 构成 关系 型 数据 库 (Database) 的 基础 。 表 是 由 这 样 的 结构 构成 : 用 列 (Cols) 
表示 的 字段 与 用 行 (Rows) 表示 的 记录 。 这 样 说 还 是 有 点 抽象 ， 举 一 个 实际 的 例子 来 说 明 这 个 问题 。 
如 某 一 个 班级 全 体 学 生 的 考试 成 绩 表 是 一 个 表 。 用 列 来 表示 每 一 个 科目 ， 用 行 来 表示 每 一 个 学 生 的 成 
绩 情况 。 这 样 ， 这 个 表 里 面 的 每 一 个 科目 ， 如 语文 、 数 学 、 英 语 、 物 理 、 化 学 、 政 治 、 历 史 等 科目 的 
成 绩 就 可 以 被 看 作 是 表 字 段 。 而 记录 每 一 个 学 生 分 数 的 行 ， 如 学 生 张 三 、 李 四 、 王 五 、 赵 六 这 些 信息 
就 可 以 被 看 作 是 表 的 记录 。 


141.2 ”关系 型 数据 库 的 功能 


FH 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 14 章 \ 关 系 型 数据 库 的 功能 .wmv 
数据 库 最 基本 的 功能 就 是 作为 数据 存储 的 载体 。 所 以 ， 存 储 各 种 各 样 的 数据 是 数据 库 最 基本 的 功 
能 。 当 然 除 了 这 个 最 基本 的 功能 之 外 ， 关 系 型 数据 库 还 具有 如 下 功能 : 
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复杂 的 数据 计算 。 把 数据 存放 于 数据 库 后 并 不 是 已 经 完成 任务 了 。 加 入 数据 只 是 数据 库 应 用 
的 开始 。 可 以 利用 数据 库 的 强大 计算 功能 来 实现 复杂 的 数据 计算 。 

数据 统计 。 有 时 还 需要 对 存放 于 数据 库 中 的 数据 进行 某 一 类 别 的 统计 。 如 果 这 项 工作 靠 人 力 
来 完成 ， 工 作 量 是 相当 可 观 的 。 而 依靠 数据 库 则 可 以 在 很 短 时 间 内 完成 对 数据 的 统计 工作 。 
数据 检索 。 有 时 还 需要 对 数据 进行 搜索 。 在 关系 型 数据 库 中 执行 SELECT 语句 能 够 在 很 短 时 


加 


加 


间 内 检索 出 所 要 的 结果 。 
其 他 功能 。 除 此 之 外 ， 关 系 型 数据 库 还 有 其 他 一 些 功能 。 如 构建 搜索 引擎 、 游 戏 服务 器 存放 


14.2 PHP 中 的 MySQL 数据 库 相 关 函 数 


GI 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 14 章 \ PHP 中 的 MySQL 数据 库 相 关 函 数 .wmv 

本 节 先 来 学 习 PHP 中 的 与 MySQL 数据 库 操作 相关 的 函数 。 通 过 对 这 些 函 数 的 学 习 ， 会 使 读者 对 
在 PHP 中 如 何 操作 数据 库 有 一 个 比较 全 面 的 了 解 。 

下 面 就 分 别 为 读者 逐个 介绍 PHP 中 与 MySQL 数据 库 操作 相关 的 常用 函数 〈 如 果 读 者 觉得 下 面 的 
内 容 枯 燥 无 味 可 以 先 简单 浏览 一 下 ， 跳 过 这 一 节 ， 直 接 看 后 面 的 内 容 ， 遇 到 相关 的 函数 再 回来 查阅 ) 。 

1. mysql_affected_rows() 函 数 

int mysql_affected_rows([resource link identifier]) 

调用 此 函数 将 返回 前 一 次 MySQL 操作 所 影响 的 记录 行 数 。 此 操作 包括 INSERT, UPDATE, 
DELETE 3 项 查询 的 操作 。 

2. mysql_close() 函 数 

bool mysql_close([resource link identifier]) 

该 函数 用 于 关闭 MySQL 连接 。mysql_close() 函 数 关 闭 指定 的 连接 标识 所 关联 的 到 MySQL 服务 器 
的 非 持 久 连 接 。 如 果 没 有 指定 link identifier, 则 关闭 上 一 个 打开 的 连接 。 通 常 不 需要 使 用 mysql_close() 
函数 来 关闭 连接 ， 因 为 已 打开 的 非 持久 连接 会 在 脚本 执行 完毕 后 自动 关闭 。 

3. mysql_connect() 函 数 

resource mysql connect([string server[,string username[,string password[,bool new link[, int client_flags]]]]]) 

该 函数 用 于 打开 一 个 到 MySQL 服务 器 的 连接 。 该 函数 的 参数 如 下 : 

server， 可 用 的 MySQL 服务 器 。 可 以 包括 端口 号 ， 如 “hostname:port”， 或 者 到 本 地 套 接 字 的 
路 径 ， 例 如 ， 对 于 localhost 的 “:/path/to/socket”。 如 果 在 php.ini 中 指令 mysql.default_host 未 
定义 〈 默 认 情 况 )， 则 默认 值 是 localhost:3306。 
username， 用 户 名 。 默 认 值 是 服务 器 进程 所 有 者 的 用 户 名 。 
password， 密 码 。 默 认 值 是 空 密码 。 
new_link， 如 果 用 同样 的 参数 第 二 次 调用 mysql_connect) Až, 将 不 会 建立 新 连接 ， 而 将 返回 
已 经 打开 的 连接 标识 。 参 数 new_link 改变 此 行为 并 使 mysql_connectO) 函 数 总 是 打开 新 的 连接 ， 


ARARA 


KA ea 


甚至 当 mysql_connect() 函 数 曾 在 前 面 被 用 同样 的 参数 调用 过 。 
client_flags ， 该 参数 可 以 是 以 下 常量 的 组 合 : MYSQL CLIENT SSL. MYSQL CLIENT 
COMPRESS、MYSQL CLIENT IGNORE_SPACE 或 MYSQL CLIENT INTERACTIVE. 这 几 
个 参数 的 意义 分 别 如 表 14.1 所 示 。 
表 14.1 MySQL 客户 端 常 量 
* E 
MYSQL CLIENT COMPRESS 
MYSQL CLIENT IGNORE SPACE 


使 用 压缩 的 通讯 协议 

允许 在 函数 名 后 留 空格 位 

允许 设置 断 开 连接 之 前 所 空闲 等 候 的 interactive timeout. 时 间 (代替 wait_ 
timeout) 

使 用 SSL 加 密 。 本 标志 仅 在 MySQL 客户 端 库 版 本 为 4.x 或 更 高 版 本 时 可 用 。 
在 PHP 4.0 和 Windows 版 的 PHP 5 安装 包 中 绑 定 的 都 是 3.23x 


如 果 成 功 则 返回 一 个 MySQL 连接 标识 ， 失 败 则 返回 False。 

4. mysql_create_db() 函 数 

bool mysql create db(string database name[,resource link identifier]) 

调用 该 函数 将 尝试 在 指定 的 连接 标识 所 关联 的 服务 器 上 建立 一 个 新 数据 库 。 参 数 database name 为 
想 要 创建 的 数据 库 名 。 参 数 link identifier 为 MySQL 的 连接 标识 符 。 如 果 没 有 指定 ， 默 认 使 用 最 后 被 
mysql_connect(0) 函 数 打开 的 连接 。 如 果 没 有 找到 该 连接 , 函数 会 尝试 调用 mysql_connect() 函 数 建立 连接 
并 使 用 它 。 如 果 发 生意 外 , 如 没有 找到 连接 或 无 法 建立 连接 , 系统 发 出 WARNING 级 别 的 警告 信息 。 
如 果 成 功 则 返回 True， 失 败 则 返回 False。 

5. mysql_data_seek() 函 数 

bool mysql_data_seek(resource result,int row number ) 

该 函数 用 于 移动 内 部 结果 的 指针 , 将 指定 的 结果 标识 result 所 关联 的 MySQL 结果 内 部 的 行 指针 移 
动 到 row number 所 指定 的 行 号 。row_number 从 0 开始 ，row_number 的 取 值 范围 应 该 从 0 到 

(mysql num rows-l) 。 但 是 如 果 结 果 集 为 空 (mysql_num_rows(0) 一 0) ， 即 数据 库 表 中 并 没有 任何 记 

录 , 要 将 指针 移动 到 0 会 失败 并 发 出 E_WARNING 级 的 错误 , 同时 mysql_data_seek0 函 数 将 返回 Falses 
本 函数 的 参数 为 :result 为 返回 类 型 为 resource. 的 结果 集 , 该 结果 集 从 mysql_query0) 函 数 的 调用 中 得 到 ; 
row number 为 想 要 设 定 的 新 的 结果 集 指 针 的 行 数 。 如 果 成 功 则 返回 True， 失 败 则 返回 False。 

6. mysqlL_db_name() 函 数 


MYSQL CLIENT INTERACTIVE 


MYSQL CLIENT SSL 


string mysql db name(resource result,int row[,mixed field]) 


调用 该 函数 将 取得 mysql_list_dbs(0) 函 数 调用 所 返回 的 数据 库 名 。 参 数 result Jy mysql list dbs()ER Zt 
调用 所 返回 的 结果 指针 。row 为 结果 集中 的 行 号 ，field 为 某 一 个 字段 名 。 此 函数 的 返回 值 : 如 果 成 功 
则 返回 数据 库 名 ， 失 败 返回 False。 如 果 返 回 了 False, Hi mysql_error0O 函 数 来 判断 错误 的 种 类 。 


7. mysql_errno() 函 数 


int mysql ermo([resource link identifier]) 


e. 
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该 函数 用 于 返回 上 一 个 MySQL 操作 中 的 错误 信息 的 数字 编码 ,。 如果 没 有 出 错 则 返回 0。 从 MySQL 
数据 库 后 端 来 的 错误 不 再 发 出 警告 ， 要 用 mysql_ermo0 函 数 来 提取 错误 代码 。 
注意 : 本 函数 仅 返 回 最 近 一 次 MySQL 函 数 的 执行 ( 不 包括 mysql_error0 和 mysql_errno0) 函 数 ) 的 错误 代 
码 ， 因 此 如 果 要 使 用 此 函数 ， 确 保 在 调用 另 一 个 MYSQL 函数 之 前 检查 它 的 值 。 如 果 指 定 了 可 选 
参数 ， 则 用 给 定 的 连接 提取 错误 代码 ， 否 则 使 用 上 一 个 打开 的 连接 。 


8. mysql_error() 函 数 
string mysql error([resource link identifier]) 
该 函数 用 于 返回 上 一 个 MySQL 操作 产生 的 文本 错误 信息 。 如 果 没 有 出 错 ， 则 返回 NULL。 如 果 没 
有 指定 连接 资源 号 ， 则 使 用 上 一 个 成 功 打 开 的 连接 从 MySQL 服务 器 提取 错误 信息 。 从 MySQL 数据 库 
后 端 来 的 错误 不 再 发 出 警告 ， 要 用 mysql_error0 函 数 来 提取 错误 文本 。 
注意 : 和 mysql_errno() 函 数 一 样 ， 本 函数 仅 返 回 最 近 一 次 MySQL 函 数 的 执行 (不 包括 mysql_error0) 和 
mysql_errno() 函 教 的 错误 文本 ) ， 因 此 如 果 要 使 用 此 函数 ， 确 保 在 调用 另 一 个 MySQL 函 数 之 前 
检查 它 的 值 。 


9. mysql_escape_string() 函 数 


string mysql escape string(string unescaped string) 

本 函数 将 unescaped string 转 义 ， 使 之 可 以 安全 用 于 mysql_query) AZt. 
注意 : mysql_escape_string() 函 数 并 不 转 义 “%” 和 “”。 

10. mysql_fetch_array() 函 数 

array mysql_fetch_array(resource result[,int result type]) 

该 函数 返回 根据 从 结果 集 取得 的 行 生成 的 数组 ， 如 果 没 有 更 多 行 则 返回 False. mysql fetch. array() 
函数 是 mysql_fetch_row() 函 数 的 扩展 版 本 。 除 了 将 数据 以 数字 索引 方式 存储 在 数组 中 之 外 ， 还 可 以 将 
数据 作为 关联 索引 存储 ， 用 字段 名 作为 键 名 。 
注意 : 如 果 结 果 中 的 两 个 或 两 个 以 上 的 列 具有 相同 字段 名 ， 最 后 一 列 将 优先 。 要 访问 同名 的 其 他 列 ， 

必须 用 该 列 的 数字 索引 或 给 该 列 起 个 别名 。 对 有 别名 的 列 ， 不 能 再 用 原来 的 列 名 访问 其 内 容 。 

11. mysql_fetch_assoc() 函 数 

array mysql fetch assoc(resource result) 

该 函数 返回 根据 从 结果 集 取得 的 行 生 成 的 关联 数组 ， 如 果 没 有 更 多 行 则 返回 False. H 
mysql_fetch_assoc0 函 数 和 用 mysql_fetch_array() 函 数 加 上 第 二 个 可 选 参数 mysql_assoc 的 结果 是 完全 相 
同 的 。 它 仅仅 返回 关联 数组 。 这 也 是 mysql_fetch_arrayO) 函 数 初 始 的 工作 方式 。 如 果 在 关联 索引 之 外 还 
需要 数字 索引 ， 还 是 要 用 mysql_fetch_array() 函 数 。 
注意 : 如 果 结 果 中 的 两 个 或 两 个 以 上 的 列 具有 相同 字段 名 ， 最 后 一 列 将 优先 。 要 访问 同名 的 其 他 列 ， 

要 么 用 mysql_fetch_row() 函 数 来 取得 数字 索引 或 给 该 列 起 个 别名 。 参 见 mysql fetch. array() à 4 
例子 中 有 关 别 名 说 明 。 本 函数 返回 的 字段 名 是 区 分 大 小 写 的。 
.9 
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12. mysql fetch field()E& 
object mysql fetch field(resource result[,int field offset]) 
该 函数 用 于 从 结果 集中 取得 列 信息 并 作为 对 象 返回 。 如 果 没 有 指定 字段 偏 移 量 ， 则 下 一 个 尚未 被 
mysql_fetch_field(0) 函 数 取 得 的 字段 将 会 被 提取 。 
对 象 的 属性 有 以 下 几 项 ， 分 别 为 : 
name 属性 为 列 名 。 
table 属性 为 该 列 所 在 的 表 名 。 
max length 为 该 列 最 大 长 度 。 如 果 该 列 不 能 为 NULL, 则 not_null 属性 为 1; 如 果 该 列 是 primary 
key， 则 primary key 属性 为 1; 如 果 该 列 是 unique key， 则 unique key 属性 为 1; 如 果 该 列 是 
non-unique key， 则 multiple key 为 属性 1; 如果 该 列 是 numeric， 则 numeric 属性 为 1; 如 果 
该 列 是 blob， 则 blob 属性 为 1。 
type 属性 为 该 列 的 类 型 。 如 果 该 列 是 无 符号 数 ， 则 unsigned 属性 为 1; 如 果 该 列 是 zero-filled， 
则 zerofill 属性 为 1。 
注意 : 本 函数 返回 的 字段 名 是 区 分 大 小 写 的 。 


13. mysql_fetch_lengths() 函 数 

array mysql fetch lengths(resource result) 

该 函数 用 于 取得 结果 集 result 中 每 个 输出 的 长 度 。 如 果 出 错 返 回 False. mysql fetch. lengths) FR Xt 
将 上 一 次 mysql. fetch. row(). mysql fetch array()ll mysql_fetch_objectO 函 数 所 返回 的 每 个 列 的 长 度 存 
储 到 一 个 数组 中 ， 偏 移 量 从 0 开始 。 

14. mysql_fetch_object() 函 数 

object mysql_fetch_object(resource result) 

该 函数 用 于 从 结果 集 result. 中 取得 一 行 作为 对 象 。 如 果 没 有 更 多 行 ， 则 返回 False. 
mysql_fetch_object() 和 mysql_fetch_array() 函 数 有 一 定 的 类 似 ， 只 有 一 点 区 别 就 是 返回 的 是 一 个 对 象 而 
不 是 数组 。 间 接地 也 意味 着 只 能 通过 字段 名 来 访问 数组 ， 而 不 是 偏 移 量 〈 数 字 是 合法 的 属性 名 ) 。 
注意 : 本 函数 返回 的 字段 名 是 区 分 大 小 写 的 。 

15. mysql_fetch_row() 函 数 

array mysql fetch row(resource result) 

该 函数 用 于 返回 根据 所 取得 的 行 生成 的 数组 ， 如 果 没 有 更 多 行 ， 则 返回 False. mysql fetch row() 
函数 从 和 指定 的 结果 标识 关联 的 结果 集中 取得 一 行 数据 并 作为 数组 返回 。 每 个 结果 的 列 存储 在 一 个 数 
组 的 单元 中 ， 偏 移 量 从 0 开始 。 依 次 调用 mysql_fetch_row() 函 数 将 返回 结果 集中 的 下 一 行 ， 如 果 没 有 
更 多 行 ， 则 返回 False。 
注意 : 本 函数 返回 的 字段 名 是 区 分 大 小 写 的 。 


16. mysqlLfield_flags() 函 数 
string mysql field flags(resource result,int field offset) 


e. 
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该 函数 返回 指定 字段 的 字段 标志 。 每 个 标志 都 用 一 个 单词 表示 ， 之 间 用 一 个 空格 分 开 ， 因 此 可 以 
用 explodeO) 函 数 把 字符 串 分 割 到 数组 中 。 

17. mysql_field_len() 函 数 

int mysql field len(resource result,int field offset) 

该 函数 用 于 返回 指定 字段 的 长 度 。 

18. mysql_field_name() 函 数 

string mysql field name(resource result,int field index) 

该 函数 返回 指定 字段 索引 的 字段 名 。 其 中 result 参数 必须 是 一 个 合法 的 结果 标识 符 ，field_index 是 
该 字段 的 数字 偏 移 量 。 
注意 : field_index 从 0 开始 。 如 第 三 个 字段 的 索引 值 其 实 是 2， 第 四 个 字段 的 索引 值 是 3， 以 此 类 推 。 本 

函数 返回 的 字段 名 是 区 分 大 小 写 的 。 
19. mysql_field_seek() 函 数 
int mysql field seek(resource result,int field offset) 


该 函数 用 于 按照 指定 的 字段 偏 移 量 检索 。 如 果 下 一 个 mysql_fetch_field(O) 函 数 的 调用 不 包括 字段 偏 
移 量 ， 则 会 返回 本 次 mysql_field_seek() 函 数 中 指定 的 偏 移 量 的 字段 。 


20. mysql_field_table() 函 数 

string mysql_field_table(resource result,int field_offset) 
该 函数 用 于 取得 指定 字段 所 在 的 表 名 。 

21. mysql_field_type() 函 数 

string mysql field type(resource result,int field offset) 


该 函数 用 于 取得 结果 集中 指定 字段 的 类 型 。 该 函数 和 mysql_field_name(O) 函 数 相似 。 参数 完全 相同 ， 
但 该 函数 返回 的 是 字段 类 型 而 不 是 字段 名 。 字 段 类 型 有 int、real、string、blob 以 及 其 他 类 型 。 


22. mysql_free_result() 函 数 


bool mysql free result(resource result) 

该 函数 用 于 释放 结果 标识 符 result 所 占用 的 内 存 。 该 函数 仅 需要 在 考虑 到 返回 很 大 的 结果 集 时 会 占 
用 多 少 内 存 时 调用 。 在 脚本 结束 后 所 有 关联 的 内 存 都 会 被 自动 释放 。 如 果 成 功 释放 内 存 则 返回 True, 
失败 则 返回 False。 


23. mysqlL_ get_client_info() 函 数 


string mysql_get_client_info() 
调用 该 函数 将 取得 MySQL. 客户 端 信息 ， 函 数 返 回 一 个 字符 串 ， 该 字符 串 代 表 了 MySQL 的 版 本 。 
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24. mysql get host info()E& Zi 

string mysql get host info([resource link identifier]) 

该 函数 用 于 取得 MySQL. EHS. mysql get host info0 函 数 返回 一 个 字符 串 说 明了 连接 
link identifier 所 使 用 的 连接 方式 ， 包 括 服务 器 的 主机 名 。 如 果 省 略 函数 link identifier， 则 使 用 上 一 个 
打开 的 连接 。 

25. mysql_get_proto_info() 函 数 

int mysql get proto info([resource link identifier]) 

该 函数 返回 参数 link identifier 所 使 用 的 协议 版 本 。 如 果 省 略 参数 link_identifier， 则 使 用 上 一 个 打 
开 的 连接 。 

26. mysql_get_server_info() 函 数 


string mysql get server info([resource link identifier]) 
该 函数 返回 参数 link_identifier 所 使 用 的 服务 器 版 本 。 如 果 省 略 参数 link_identifier， 则 使 用 上 一 个 
打开 的 连接 。 
27. mysql_info() 函 数 
string mysql info([resource link_identifier]) 
该 函数 返回 通过 给 定 的 参数 link. identifier 所 进行 的 最 新 一 条 查询 的 详细 信息 。 如 果 没 有 指定 参数 
link_identifier， 则 假定 为 上 一 个 打开 的 连接 。 
mysql_info() 函 数 对 以 下 列 出 的 所 有 语句 返回 一 个 字符 串 。 对 于 其 他 任何 语句 返回 False。 字 符 串 的 
格式 取决 于 给 出 的 语句 。 起 作用 的 语句 如 下 所 示 : 
INSERT INTO SELECT 插入 语句 。 
INSERT INTO VALUES 插入 语句 。 
LOAD DATA INFILE 载 入 数据 语句 。 
ALTER TABLE 改变 表 结 构 语 句 。 
UPDATE 更 新 记录 语句 。 
28. mysql insert. id() 23 
int mysql insert id([resource link identifier]) 
调用 该 函数 将 返回 给 定 的 参数 link_identifier 中 上 一 步 INSERT 查询 中 产生 的 AUTO_INCREMENT 
的 ID 号 。 如果 没 有 指定 参数 link_identifier, 则 使 用 上 一 个 打开 的 连接 。 如 果 上 一 查询 没有 产生 AUTO_ 
INCREMENT 的 值 ， 则 mysql_insert_id() 函 数 将 会 返回 0。 如 果 需 要 保存 该 值 以 后 使 用 ， 要 确保 在 产生 
了 值 的 查询 后 立即 调用 mysql. insert. id); A. 
注意 : MySQL 中 的 SQL 函数 last_insert id() 总 是 保存 着 最 新 产生 的 AUTO_INCREMENT 值 ， 并 且 不 会 在 
查询 语句 之 间 被 重 置 。mysql_insert_ id() 函 数 将 MySQL 内 部 的 C API 函 数 mysql_insert_id() 的 返回 
值 转换 成 Iong (PHP 中 命名 为 int ) 。 如 果 AUTO _INCREMENT 的 列 的 类 型 是 BIGINT ， 则 
mysql insert idO 函 数 返 回 的 值 将 可 能 不 正确 。 可 以 在 SQL 查询 中 用 MySQL 内 部 的 SQL 函数 
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last_insert_id() 来 蔡 代 以 取得 上 一 步 INSERT 操 作 产 生 的 ID。 
29. mysql_list_dbs() 函 数 
resource mysql list dbs([resource link identifier]) 


调用 该 函数 将 返回 一 个 结果 指针 ， 包 含 了 当前 MySQL 进程 中 所 有 可 用 的 数据 库 。 用 mysql 
tablenameO 函 数 来 遍历 此 结果 指针 ， 或 者 任何 使 用 结果 表 的 函数 。 


30. mysql list processes()E Eit 


resource mysql list processes([resource link identifier]) 

该 函数 返回 一 个 结果 指针 ， 说 明了 当前 服务 器 的 线程 。 
31. mysqlL_num_fields() 函 数 

int mysql num fields(resource result) 

调用 该 函数 将 会 返回 结果 集中 字段 的 数目 。 

32. mysql_num_rows() 函 数 


int mysql_num_rows(resource result) 

调用 此 函数 将 会 返回 结果 集中 行 的 数目 。 此 命令 仅 对 SELECT 语句 有 效 。 要 取得 被 INSERT 插入 、 
UPDATE 更 新 或 者 DELETE 删除 查询 所 影响 到 的 行 的 数目 ， 用 mysql_affected_rows0) 函 数 。 

33. mysql_pconnect() 函 数 

resource mysql_pconnect(string server[,string username[,string password[,int client flags]]]]) 

该 函数 调用 成 功 则 返回 一 个 正确 的 MySQL. 持久 连接 标识 符 ， 出 错 则 返回 False. mysgl. peonnect() RZ 
建立 一 个 到 MySQL 服务 器 的 连接 。 如 果 没 有 提供 可 选 参数 ， 则 使 用 如 下 默认 值 : server= 'localhost:3306', 
username= 服 务 器 进程 所 有 者 的 用 户 名 ，password= 空 密码 。client_flags 参数 可 以 是 以 下 常量 的 组 合 : 
MySQL CLIENT COMPRESS.MySQL CLIENT IGNORE _ SPACE 或 者 MySQL_CLIENT_INTERACTIVE。 
server 参数 也 可 以 包括 端口 号 ， 如 "hostname:port"， 或 者 是 本 机 套 接 字 的 路 径 ， 如 ":/path/to/socket"。 
注意 : 对 ":port" 端 口 的 支持 是 PHP 3.0B4 版 添加 的 。 对 本 机 套 接 字 的 路 径 ":/path/to/socket" 的 支持 是 PHP 

3.0.10 版 添加 的 。 可 选 参 数 client_flags 自 PHP 4.3.0 版 起 作用 。 此 种 连接 称 为 “持久 的 ”。 


mysql_pconnect() 和 mysql_connect0 函 数 非常 相似 ， 但 有 两 个 主要 区 别 : 
当 连 接 的 时 候 本 函数 将 先 尝试 寻找 一 个 在 同一 个 主机 上 用 同样 的 用 户 名 和 密码 已 经 打开 的 
(持久 ) 连接 ， 如 果 找 到 ， 则 返回 此 连接 标识 而 不 打开 新 连接 。 
当 脚 本 执行 完毕 后 到 SQL 服务 器 的 连接 不 会 被 关闭 ， 此 连接 将 保持 打开 以 备 以 后 使 用 
(mysql_close() 函 数 不 会 关闭 由 mysql_pconnect(O) 函 数 建立 的 连接 )。 
注意 : 此 种 连接 仅 能 用 于 模块 版 本 的 PHP。 


34. mysql_ping() 函 数 
bool mysql ping([resource link identifier ]) 


a) 


mysql ping( EA IUS APRA ss XE BE AE p. WA, Au, ARAFE 
很 久 的 脚本 来 检查 服务 器 是 否 关 闭 了 连接 ， 如 果 有 必要 则 重新 连接 上 。 如 果 到 服务 器 的 连接 可 用 ， 则 
mysql ping(0) 函 数 返 回 True， 否 则 返回 False。 

35. mysql_query() 函 数 

resource mysql query(string query[,resource link identifier]) 

mysql_query() 函 数 向 与 指定 的 连接 标识 符 关联 的 服务 嚣 中 的 当前 活动 数据 库 发 送 一 条 查询 。 如 果 
没有 指定 参数 link_identifier， 则 使 用 上 一 个 打开 的 连接 。 如 果 没有 打开 的 连接 ， 本 函数 会 尝试 无 参数 
调用 mysql_connect() 函 数 来 建立 一 个 连接 并 使 用 之 。 查 询 结果 会 被 缓存 。 
注意 : 查询 字符 串 不 应 以 分 号 结束 。 


另外 ，mysql_query() 函 数 仅 对 SELECT、SHOW、EXPLAIN 或 DESCRIBE 语句 返回 一 个 资源 标识 
符 ， 如 果 查 询 执行 不 正确 则 返回 False。 对 于 其 他 类 型 的 SQL 语句 ，mysql_query() 函 数 在 执行 成 功 时 返 
回 True， 出 错时 返回 False. 3E False 的 返回 值 意 味 着 查询 是 合法 的 并 能 够 被 服务 器 执行 。 这 并 不 说 明 
任何 有 关 影 响 到 的 或 返回 的 行 数 。 很 有 可 能 一 条 查询 执行 成 功 了 但 并 未 影响 到 或 并 未 返回 任何 行 。 

如 果 没 有 权限 访问 查询 语句 中 引用 的 表 时 ，mysql_query() 函 数 也 会 返回 Falses 

假定 查询 成 功 ， 可 以 调用 mysql_num_rows() 函 数 来 查看 对 应 于 SELECT 语句 返回 了 多 少 行 ， 或 者 
调用 mysql_affected_rows() 函 数 来 查看 对 应 于 DELETE, INSERT, REPLACE 或 UPDATE 语句 影响 到 
了 多 少 行 。 

仅 对 SELECT. SHOW, DESCRIBE 或 EXPLAIN 语句 mysql_query0 函 数 才 会 返回 一 个 新 的 结果 
标识 符 ， 可 以 将 其 传递 给 mysql_fetch_array() 函 数 和 其 他 处 理 结果 表 的 函数 。 处 理 完结 果 集 后 可 以 通过 
调用 mysql_free_result() 函 数 来 释放 与 之 关联 的 资源 ， 尽 管 脚本 执行 完毕 后 会 自动 释放 内 存 。 


36. mysql_real_escape_string() 函 数 


string mysql real escape string(string unescaped string[,resource link identifier]) 

本 函数 将 unescaped string 中 的 特殊 字符 转 义 ， 并 计 及 连接 的 当前 字符 集 ， 因 此 可 以 安全 用 于 
mysql_queryO 函 数 。 
注意 : mysql real escape _string() 函 数 并 不 转 义 “%” 和 “”。 


37. mysql_result() 函 数 

mixed mysql_result(resource result,int row[,mixed field]) 

调用 该 函数 将 返回 MySQL 结果 集中 一 个 单元 的 内 容 。 字 段 参数 可 以 是 字段 的 偏 移 量 或 者 字段 名 ， 
或 者 是 字段 表 点 字段 名 Cablename.fieldname) 。 如 果 给 列 起 了 别名 Cselect foo as bar from...) ， 则 用 
别名 替代 列 名 。 

当 作用 于 很 大 的 结果 集 时 ， 应 该 考虑 使 用 能 够 取得 整 行 的 函数 〈 在 下 边 指出 ) 。 这 些 函数 在 一 次 
函数 调用 中 返回 了 多 个 单元 的 内 容 ， 比 mysql_result() 函 数 快 得 多 。 此 外 注意 在 字段 参数 中 指定 数字 偏 
移 量 比 指定 字段 名 或 者 tablename.fieldname 要 快 得 多 。 
注意 : 调用 mysql result0 函 数 不 能 和 其 他 处 理 结果 集 的 函数 混合 调用 。 


@ 


zus 使 有 MySQL 到 二 话 


38. mysql_select_db() 函 数 

bool mysg| select db(string database_namel,resource link identifier]) 

该 函数 将 选择 指定 的 MySQL. 数据 库 。 如 果 成 功 则 返回 True， 失 败 则 返回 False. mysql select db() 
函数 设 定 与 指定 的 连接 标识 符 所 关联 的 服务 器 上 的 当前 激活 数据 库 。 如 果 没有 指定 连接 标识 符 ， 则 使 
用 上 一 个 打开 的 连接 。 如 果 没 有 打开 的 连接 ， 本 函数 将 无 参数 调用 mysql_connect() 函 数 来 尝试 打开 一 
个 并 使 用 之 。 

39. mysql_stat() 函 数 

string mysql stat([resource link identifier]) 

mysql_stat(O) 函 数 返 回 当前 服务 器 状态 。 
注意 : mysql_statO 函 数目 前 只 返回 uptime threads, queries, open tables, flush tables 和 queries per second, 

要 得 到 其 他 状态 变量 的 完整 列表 ， 只 能 使 用 SQL 命令 SHOW STATUS, ， 取 得 当前 系统 状态 。 


40. mysql_tablename() 函 数 

string mysql tablename(resource result,int i) 

mysql_tablename() 函 数 接受 mysql_list_tables() 函 数 返回 的 结果 指针 以 及 一 个 整数 索引 作为 参数 并 
返回 表 名 。 可 以 用 mysql_num_rows0 函 数 来 判断 结果 指针 中 的 表 的 数目 。 用 mysql. tablenameQ ER OE 
遍历 此 结果 指针 ， 或 者 任何 处 理 结果 表 的 函数 。 

41. mysql thread id() 函 数 

int mysql thread id([resource link identifier]) 

mysql_thread_id0) 函 数 返 回 当前 线程 的 ID。 如果 连 接 丢 失 了 并 用 mysql_ping() 函 数 重新 连接 上 ， 线 
程 ID 会 改变 。 这 意味 着 不 能 取得 线程 的 ID 后 保存 起 来 备用 。 当 需要 的 时 候 再 去 获取 之 。 

42. mysqlL_unbuffered_query() 函 数 

resource mysql unbuffered query(string query[,resource link identifier]) 

该 函数 向 MySQL 发 送 一 条 SQL 查询 query, 但 不 像 mysqL_query0) 函 数 那样 自动 获取 并 缓存 结果 集 。 一 
方面 ， 这 在 处 理 很 大 的 结果 集 时 会 节省 可 观 的 内 存 ， 另 一 方面 ， 可 以 在 获取 第 一 行 后 立即 对 结果 集 进 行 操 
作 ， 而 不 用 等 到 整个 SQL 语句 都 执行 完毕 。 当 使 用 多 个 数据 库 连 接 时 ， 必 须 指 定 可 选 参数 link identifier. 

PHP 中 的 MySQL 函数 就 为 读者 介绍 到 这 里 。 实 际 上 这 些 函 数 中 ， 有 一 些 是 不 太 常 用 的 。 读 者 不 
必 完 全 掌握 ， 如 果 在 实际 操作 中 见 到 这 样 的 函数 ， 知 道 是 如 何 起 作用 的 即 可 。 但 对 于 一 些 常 用 的 函数 
则 必须 要 熟练 掌握 ， 因 为 熟练 掌握 其 中 的 常用 函数 是 学 好 数据 库 的 前 提 。 


14.3 ”数据 库 操作 


本 节 就 来 学 习 实际 对 数据 库 的 操作 。 内 容 包 括 如 何 连接 MySQL 服务 器 、 如 何 显示 目前 的 数据 库 
如 何 创 建 一 个 数据 库 、 如 何在 选 定数 据 库 中 创建 表 及 如 何 删除 已 存在 的 库 和 表 等 。 
i9) 
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14.3.1 连接 MySQL 服务 器 


GH 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 14 章 \ 连 接 MySQL 服务 器 .wmv 
所 有 对 MySQL 数据 库 的 操作 都 要 在 主机 提供 MySQL 服务 的 前 提 下 进行 。 连接 提供 了 此 项 服务 的 
主机 是 进行 数据 库 操 作 的 前 提 。 所 以 在 进行 数据 库 操作 前 必须 要 连接 到 MySQL 服务 器 。 
在 PHP 编程 环境 下 要 连接 到 MySQL 服务 器 ， 需 要 使 用 mysql_connectO) 函 数 。 该 函数 有 3 个 参数 ， 
第 一 个 参数 为 主机 名 ; 第 二 个 参数 为 用 户 名 ; 第 三 个 参数 为 该 用 户 的 密码 。 此 函数 连接 到 MySQL 服 
务 器 ， 如 果 成 功 返 回 True， 反 之 返回 False。 
【实例 14-1】 以 下 代码 演示 如 何 使 用 mysql_connect0 函 数 来 连接 到 MySQL 服务器。 


re 实例 14-1: 使 用 mysql_connect(O) 函 数 来 连接 到 MySQL 服务 器 
源码 路 径 光盘 \ 源 文件 \14\14-1.php 


01 <html> 

02 <head> 

03 ”<title> 连 接 MySQL 服务 器 </title> 

04 </head> 

05 <body> 

06 <?php 

07 $db. host-"localhost"; IIMySQL 服务 器 名 

08 $db_user="root"; /MySQL 用 户 名 

09 $db_pass="admin"; /MySQL 用 户 对 应 密码 

10 // 使 用 mysql_connect() 函 数 对 服务 器 进行 连接 ， 如 果 出 错 ， 则 返回 相应 信息 
11 $linkzmysql connect($db host,$db user,$db pass)or die(" 不 能 连接 到 服务 器 ".mysql_error()); 
12 echo "成 功 连接 到 服务 器 "; // 如 果 连 接 成 功 ， 则 显示 信息 
13 ?> 

14 </body> 

15 </html> 


开启 Apache 服务 及 MySQL 服务 〈 本 章 实例 均 需 要 两 种 服务 共同 支持 ， 下 同 ) ,在 PHP 运行 环境 
下 执行 该 PHP 文件 ， 执 行 结 果 如 图 14.1 所 示 。 


成 功 连接 到 服务 吗 
K100% ~ 


图 14.1 连接 MySQL 服务 器 执行 结果 
上 面 代 码 中 mysql_connect() 函 数 的 作用 是 连接 到 MySQL 服务 器 ， 它 带 有 3 个 string 参数 。 第 一 个 
参数 指 主机 名 ， 第 二 个 参数 是 用 户 名 ， 第 三 个 参数 是 用 户 密码 。 这 些 信息 都 由 MySQL 服务 提供 者 提 
供 。 后 面 的 or die() 函 数 指 如 果 不 能 正确 连接 MySQL 服务 器 的 返回 信息 。 
执行 以 上 操作 ， 如 果 正 确 无 误 就 能 正确 连接 到 MySQL 服务 器 ， 如 图 14.1 所 示 。 如 果 关 闭 MySQL 
服务 就 会 导致 无 法 连接 到 服务 器 ， 则 程序 会 输出 如 下 信息 : 
不 能 连接 到 服务 器 Can't connect to MySQL server on 'localhost' (10061) 


e. 
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14.3.2 ”连接 到 服务 器 并 显示 可 用 数据 库 


GE 知识 点 讲解 :光盘 \ 视 频 讲 解 \ 第 14 章 \ 连 接 到 服务 器 并 显示 可 用 数据 库 .wmv 

连接 到 MySQL 服务 器 后 ， 下 一 步 就 是 了 解 当前 数据 库 的 状况 。 因 为 具有 了 解 服务 器 上 的 可 用 数 
据 库 信 息 ， 才 能 使 用 户 决定 下 一 步 要 如 何 操作 。 下 面 讲解 如 何 显示 可 用 的 数据 库 。 要 显示 服务 器 上 的 
数据 库 情 况 ， 需 使 用 mysql_list_dbs0 函 数 。 该 函数 有 一 个 参数 ， 此 参数 为 已 经 建立 的 服务 器 连接 。 

【实例 14-2】 以 下 代码 演示 如 何 使 用 mysql_list_dbs0 函 数 来 显示 服务 器 上 的 可 用 数据 库 。 


TE | 实例 14-2: 使 用 mysql_list_dbs( 函 数 来 显示 服务 器 上 的 可 用 数据 库 


源码 路 径 : 光盘 \ 源 文件 \14\14-2.php 


<head> 
<title> 显 示 数 据 库 </title> 
</head> 
<body> 
<?php 
$db host-"localhost"; /MySQL 服务 器 名 
$db_user="root"; /MySQL 用 户 名 
$db_pass="admin"; IIMySQL 用 户 对 应 密码 
// 使 用 mysql_connect() 函 数 对 服务 器 进行 连接 ， 如 果 出 错 ， 则 返回 相应 信息 
$link=mysql_connect($db_host,$db_user,$db_pass)or die(" 不 能 连接 到 服务 器 ".mysql_error()); 


$db_list=mysql_list_dbs($link); /显示 数据 库 ， 参 数 为 上 一 步 的 服务 器 连接 
while($db=mysql_fetch_object($db_list) // 通 过 循环 遍历 返回 的 结果 集 
echo $db->Database; /显示 数据 库 名 ， 注 意 大 小 写 
echo "«p»"; 
) 
?> 
</body> 
</html> 


在 PHP 运行 环境 下 执行 该 PHP 文件 ， 执 行 结果 如 图 14.2 所 示 。 


8 httpi//localhost/14 £ 
Ta ene 国 
mysql 
performance schema 
test vi 


*10€ ~ 


图 14.2 ”显示 数据 库 执行 结果 


14.3.3 ”在 服务 器 上 创建 新 的 数据 库 


GE 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 14 章 \ 在 服务 器 上 创建 新 的 数据 库 .wmv 
对 数据 库 进 行 操作 时 ， 系 统 提供 的 数据 库 通常 是 有 限 的， 所 以 需要 在 服务 器 上 建立 新 的 数据 库 。 


KA aaa 


下 面 介 绍 如 何在 服务 器 上 创建 一 个 新 的 数据 库 。 
创建 数据 库 时 使 用 mysql_query0) 函 数 来 发 送 一 条 SQL 语句 达到 创建 数据 库 的 目的 。 
【实例 14-3】 以 下 代码 演示 使 用 mysql_query() 函 数 创 建新 的 数据 库 。 


re 实例 14-3: 使 用 mysql_query() 函 数 创建 新 的 数据 库 
源码 路 径 : 光盘 \ 源 文件 \14\14-3.php 


01 <html> 
02 «head» 
03 «title» (WA SQL 语句 创建 新 的 数据 库 </title> 
04 </head> 
05 <body> 
06 <?php 
07 $db host-'localhost"; /MySQL 服务 器 名 
08 $db user-"root"; /MySQL 用 户 名 
09 $db_pass="admin"; /MySQL 用 户 对 应 密码 
10 // 使 用 mysql_connect() 函 数 对 服务 器 进行 连接 ， 如 果 出 错 ， 则 返回 相应 信息 
11 S$link=mysql_connect($db_host,$db_user,$db_pass)or die(" 不 能 连接 到 服务 器 ".mysql_error()); 
12 $sql="CREATE DATABASE database1"; /创建 数据 库 的 SQL 语句 
13 if(mysql_query($sql,$link)) /发 送 SQL 语句 
14 echo "数据 库 创 建成 功 "; // 如 果 创 建成 功 ， 则 显示 信息 
15 echo "<p>"; 
16 echo "当前 服务 器 上 的 所 有 数据 库 为 :"; 
Vtt echo "<p>"; 
18 $db listzmysql list dbs(Slink); /显示 数据 库 
19 while($db=mysql_fetch_object($db_list)) // 通 过 循环 遍历 返回 的 结果 集 
20 { 
21 echo $db-»Database; /显示 数据 库 名 ， 注 意 大 小 写 
22 echo "<p>"; 
23 ) 
24 ?> 
25 </body> 
26 </html> 
在 PHP 运行 环境 下 执行 该 PHP 文件 ， 执 行 结果 如 图 14.3 所 示 。 
| in 
[€] E htg//locahosy14 D + 
款 据 库 创建 成 功 ^ 
当前 服务 器 上 的 所 有 数据 库 为， 
infommaton schema 
|| databaser 
mysql 
|| performance_schema 
图 143 使 用 SQL 语句 来 创建 新 的 数据 库 执行 结果 


要 注意 的 是 ， 创 建 数 据 库 的 SQL 语句 的 语法 为 “CREATE DATABASE” 后 面 加 上 想 要 创建 的 数 


e. 


第 14 章 使 用 MySQL £ 


据 库 名 称 即 可 。 然 后 使 用 mysql_query0) 函 数 来 发 送 SQL 语句 ， 来 达到 创建 数据 库 的 目的 。 


14.3.4 在 选 定数 据 库 里 创建 表 


EH 知识 点 讲解 : 光盘 \ 视 频 讲 解 \ 第 14 章 \ 在 选 定数 据 库 里 创建 表 -wmv 

通过 前 面 的 介绍 读者 能 了 解 到 ， 表 是 数据 库 的 主要 构成 元 素 。 有 了 数据 库 还 必须 有 特定 的 表 才 能 
发 挥 作用 ， 因 为 基本 上 所 有 的 数据 库 操作 都 是 在 表 中 进行 的 。 本 小 节 就 来 介绍 如 何在 数据 库 里 创建 表 。 
注意 : 服务 器 上 MySQL 数 据 库 是 运行 MySQL 服 务 的 关键 库 ， 不 要 尝试 对 该 库 进行 操作 ,更 不 要 对 里 面 

的 表 进 行 添加 、 人 删除、 修改 等 操作 。 

要 想 在 数据 库 中 创建 表 ， 要 使 用 mysql_query0 函 数 发 送 SQL 语句 来 实现 。 

创建 表 的 SQL 语句 的 语法 如 下 所 示 : 

create table table name (column name data (identity |null|not null}, +++) 

其 中 参数 table name (#4) 和 column name 〈 列 名 ) 即 字段 名 必须 满足 用 户 数据 库 中 的 识别 器 

(identifier) 的 要 求 ,参数 data 是 一 个 标准 的 SQL 类 型 或 由 用 户 数据 库 提 供 的 类 型 .用 户 要 使 用 non-null 

从 名 为 各 字段 输入 数据 。 

create table 还 有 一 些 其 他 选项 ， 如 创建 临时 表 和 使 用 SELECT 子 句 从 其 他 的 表 中 读 取 某 些 字段 组 
成 新 表 等 。 还 有 ， 在 创建 表 时 可 用 PRIMARY KEY、KEY、INDEX 等 标识 符 设 定 某 些 字段 为 主键 或 索 


引 等 。 
书写 上 要 注意 : 

在 一 对 圆 括号 里 的 列 出 完整 的 字段 清单 。 

字段 名 间 用 逗号 隔 开 。 

字段 名 间 的 逗号 后 要 加 一 个 空格 。 

最 后 一 个 字段 名 后 不 用 逗号 。 

所 有 的 SQL 陈述 都 以 分 号 “;” 结 束 。 

如 下 面 的 这 一 句 : 

$sql-"create table table1(id int(5) not null auto increment primary key, name varchar(12) not null,mail 

varchar(30) not null,phone varchar(14) not null,address varchar(30) not null)"; 

上 面 的 SQL 语句 定义 了 一 个 表 ， 表 有 这 样 几 个 字段 : id、name、mail、phone、address ^$. Jf H. 
还 为 每 个 字段 指定 了 类 型 。 其 中 的 id 字段 有 primart 属性 和 auto. increment 这 样 的 属性 。 其 中 primary 
指明 该 字段 为 表 的 主键 《有 唯一 值 ) ;而 auto increment 则 指明 这 个 字段 是 自动 增加 的 。 

【实例 14-4】 以 下 代码 演示 使 用 上 面 定 义 的 SQL 语句 在 test 库 中 创建 一 个 名 为 testl 的 表 。 


RAARARA 


K | 实例 14-4. 使 用 SQL 语句 在 test 库 中 创建 一 个 名 为 testl 的 表 
OW 源码 路 径 : NA MA Aah OO 
01 «html» 

02 «head» 

03 ”<title> 在 库 中 创建 新 表 </title> 

04 </head> 

05 <body> 


KA aaa 


06 


<?php 
$db host-"localhost"; /MySQL 服务 器 名 
$db_user="root"; IIMySQL 用 户 名 
$db pass-"admin"; IIMySQL 用 户 对 应 密码 
$db name-"test"; // 要 操作 的 数据 库 


// 使 用 mysql_connect() 函 数 对 服务 器 进行 连接 ， 如 果 出 错 ， 则 返回 相应 信息 
$link=mysql_connect($db_host,$db_user,$db_pass)or die(" 不 能 连接 到 服务 器 ".mysql_error()); 
mysql_select_db($db_name, $link); /| 选择 相应 的 数据 库 ， 这 里 选择 test HE 

/下面 的 $sql 就 为 创建 表 的 SQL 语句 

$sql="create table test1(id int(5) not null auto_increment primary key, name varchar(12) not 


null,mail varchar(30) not null,phone varchar(14) not null,address varchar(30) not null)"; 


28 
29 


if(mysgl. query($sql,$link)) /发 送 SQL 语句 执行 创建 表 的 操作 
echo " 表 test1 创建 成 功 "; // 如 果 创建 成 功 ， 则 显示 信息 

echo "<p>"; 

echo "当前 ".$db_name." 上 的 所 有 数据 表 为 "S 

echo "<p>"; 


S$table listzmysql list tables($db name,Slink); /显示 数据 库 中 的 表 
while($row=mysql_fetch_row($table list) // 通 过 循环 遍历 返回 的 结果 集 


echo $row[0]; /显示 表 名 


echo "<p>"; 


</body> 
</html> 


在 PHP 运行 环境 中 执行 该 PHP 文件 ， 执 行 结果 如 图 14.4 所 示 。 


表 testl 记 建成 功 gl 


当前 es 上 的 所 有 数据 表 为 ， 


testl 


图 14.4 在 库 中 创建 新 表 执行 结果 


以 上 实例 中 使 用 了 mysql_list_tables() 函 数 ， 该 函数 的 作用 是 显示 库 中 所 有 的 表 。 就 像 前 面 讲 到 的 
创建 数据 库 函数 mysql_create_db0 一 样 ,， 该 函数 也 已 经 被 废弃 ， 所 以 不 推荐 使 用 , 可 以 用 mysql. query 
函数 发 送 一 条 SQL 语句 来 达到 和 函数 一 样 的 目的 。 显 示 所 有 数据 表 的 SQL 语句 是 : show tables。 

下 面 把 上 面 的 代码 做 一 下 调整 ， 把 其 中 的 : 

$table listzmysql list tables($db name,Slink); 

一 句 更 换 为 : 

S$table_list=mysql_query("show tables", $link); 

然后 ， 重 新 执行 修改 过 的 PHP 文件 ， 可 以 看 到 执行 结果 是 完全 相同 的 (再 次 执行 时 要 把 创建 表 相 
关 几 行 都 注释 掉 ， 或 者 再 换个 表 名 进行 创建 才 行 。 因 为 对 已 经 存在 的 表 进 行 创建 就 会 导致 错误 ) 。 


e. 
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14.3.5 ”如何 删除 已 经 存在 的 库 和 表 


GH 知识 点 讲解 :光盘 \ 视 频 讲 解 \ 第 14 章 \ 如 何 删除 已 经 存在 的 库 和 表 .wmv 

如 果 确 认 数据 库 或 者 里 面 的 表 已 经 不 再 需要 ， 就 可 以 将 库 或 者 表 删 除 。 如 何 删除 库 或 者 表 呢 ? 

删除 一 个 库 可 以 通过 mysql_queryO 函 数 发 送 SQL 语句 : drop database database name. 

而 删除 一 个 表 则 通过 mysql_query0) 函 数 发 送 SQL 语句 : drop table table name. 

下 面 分 别 来 介绍 如 何 删除 表 及 库 。 

先 来 看 如 何 删除 一 个 表 。 删除 表 是 靠 mysql_query() 函 数 来 发 送 SQL 语句 : drop table name 来 实现 ， 
其 中 的 table name 指 代 将 要 被 删除 的 表 名 。 

【实例 14-5】 以 下 代码 演示 如 何 删除 test 库 中 的 表 test1。 


EF ] 实例 14-5: 如 何 删 除 test 库 中 的 表 tt AA 
源码 路 径 ， 光盘 \ 源 文件 \14\14-5.php 


01 <html> 

02 <head> 

03 ”<title> 在 库 中 删除 表 </title> 

04 </head> 

05 <body> 

06 <?php 

07 $db host-"localhost"; /MySQL 服务 器 名 

08 $db userz"root"; /MySQL 用 户 名 

09 $db_pass="admin"; IIMySQL 用 户 对 应 密码 

10 $db_name="test"; // 要 操作 的 数据 库 

11 /使 用 mysql_connect() 函 数 对 服务 器 进行 连接 ， 如 果 出 错 ， 则 返回 相应 信息 

12 $linkzmysql connect($db host,$db user$db pass)or die(" 不 能 连接 到 服务 器 ".mysql_error()); 
13 mysql select db($db name,Slink); /选择 相应 的 数据 库 ， 这 里 选择 test Æ 
14 echo "当前 ".$db_name." 上 的 所 有 数据 表 为 : "; // 先 显示 表 删 除 之 后 再 显示 以 作 比 较 
15 echo "<p>"; 

16 $table list-mysql list tables($db name,Slink); /显示 数据 库 中 的 表 

17 while($row-mysql fetch row(Stable list) // 通 过 循环 遍历 返回 的 结果 集 

18 

19 echo $row[0]; /显示 表 名 

20 echo "«p»"; 

21 H 

22 $sql="drop table testi"; /删除 表 的 SQL 语句 

23 if(mysql_query($sql,$link)) /| 执行 SQL 语句 

24 echo "X test! 已 经 被 删除 ! "; 

25 echo "«p»"; 

26 echo "当前 ".$db_name." 上 的 所 有 数据 表 为 : "; // 再 次 显示 删除 之 后 的 表 以 作 比 较 
27 echo "«p»"; 

28 Stable listzmysql query("show tables" $link); /显示 数据 库 中 的 表 

29 while($row=mysql_fetch_row($table list) // 通 过 循环 遍历 返回 的 结果 集 

30 

31 echo $row[0]; / 旺 示 表 名 

32 echo "<p>"; 

33 ) 


KA PHP Rg; 


34 7> 
35 </body> 
36 </html> 


在 PHP 运行 环境 下 执行 该 PHP 文件 (在 执行 前 要 确认 已 经 建立 了 test 库 及 test] R) ， 执 行 结 果 
将 会 如 图 14.5 所 示 。 


ET 


当前 we 上 的 所 有 雪 据 表 为 ， 人 


test] 
表 testl 已 经 被 删除 ! 
当前 ea 上 的 所 有 数据 表 为 ， 


14.5 ”删除 库 中 的 表 执 行 结果 
通过 图 14.5 可 以 看 到 ， 在 执行 删除 表 的 SQL 语句 之 前 ， 对 库 进行 遍历 ， 库 中 有 表 testl 。 在 执行 
完 删 除 表 的 SQL 语句 后 ， 再 次 遍历 库 已 经 不 存在 test] 表 了 。 说 明 该 表 已 经 被 成 功 删除 。 接 下 来 学 习 
如 何 删 除 库 。 
【实例 14-6】 以 下 代码 实现 了 把 服务 器 上 的 名 为 data2 的 数据 库 进行 删除 (在 执行 前 请 确保 MySQL 
服务 器 中 有 data2 这 个 数据 库 ) 。 


EON 


«html» 

<head> 

<title> 删 除 服务 器 上 的 数据 库 </title> 

</head> 

<body> 

<?php 
$db_host="localhost"; IIMySQL 服务 器 名 
$db_user="root"; /MySQL 用 户 名 
$db_pass="admin"; /MySQL 用 户 对 应 密码 
// 使 用 mysql_connect() 函 数 对 服务 器 进行 连接 ， 如 果 出 错 ， 则 返回 相应 信息 
$link-mysg! connect($db host,$db user,$db pass)or die(" 不 能 连接 到 服务 器 ".mysql_error()); 
S$db_list=mysql_list_dbs($link); // 先 显示 数据 库 以 与 删除 后 作 比较 
while($db=mysql_fetch_object($db_list) // 通 过 循环 遍历 返回 的 结果 集 


echo $db->Database; /显示 数据 库 名 ， 注 意 大 小 写 
echo "<p>"; 


01 
02 
03 
04 
05 
06 
07 
08 
09 
10 
11 
12 
13 
14 
15 
16 
17 H 

18 $sql="drop database data2"; /删除 数据 库 的 SQL 语句 
19 if(mysql_query($sql,$link)) /| 执行 SQL 语句 
20 echo "数据 库 data2 已 经 被 删除 !"; 

21 echo "<p>"; 

22 echo "当前 服务 器 上 的 所 有 数据 库 为 :"; // 再 次 显示 删除 后 的 数据 库 以 作 比 较 
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23 echo "<p>"; 


24 $db listzmysql list dbs(Slink); / 星 示 数 据 库 

25 while($db=mysql_fetch_object($db_ list) // 通 过 循环 遍历 返回 的 结果 集 
26 ( 

27 echo $db->Database; /显示 数据 库 名 ， 注 意 大 小 写 
28 echo "<p>"; 

29 ) 

30 ? 

31 </body> 

32 «html» 


在 PHP 运行 环境 中 执行 该 PHP 文件 ， 执 行 结果 如 图 14.6 所 示 。 


= 一 
PELE— 


informaton schema ^ 


|| data? 

dotabasel 

mysl 

performance schema 
test 

|| 数据库 data? 已 经 被 删除 
当前 服务 器 上 的 所 在 数 据 库 为 : 
infomation schema 
databasel 

mysql 

performance schema 


test v 


^uo v 
图 14.6 ”删除 服务 器 上 的 数据 库 执行 结果 


通过 对 照 SQL 执行 前 后 对 服务 器 上 数据 库 的 遍历 可 以 看 到 ， 执 行 完 SQL 语句 后 ， 名 为 data2 的 数 
据 库 被 删除 了 ， 说 明 以 上 程序 正常 运行 。 

在 使 用 对 数据 库 操作 时 有 一 点 需要 注意 ， 由 于 当前 的 服务 提供 商 一 般 对 于 一 个 用 户 只 提供 一 个 数 
据 库 ， 所 以 普通 用 户 只 能 在 该 库 内 对 表 进行 操作 ， 无 权 创建 或 者 删除 数据 库 。 所 以 在 执行 相关 操作 时 
是 不 会 有 结果 的 ， 如 果 在 本 机 上 进行 调试 ， 就 没有 这 个 限制 了 。 


14.4 对 MySQL 表 进 行 操作 


在 创建 了 库 ， 并 为 库 创 建 了 相应 的 表 后 ， 就 可 以 对 表 中 的 数据 进行 操作 了 。 其 实 对 表 的 操作 无 非 
就 是 插入 、 浏 览 、 修 改 、 删 除 ， 而 这 几 项 操作 都 可 以 通过 mysql_queryO 函 数 发 送 相关 的 SQL 语句 来 实 
现 。 本 节 就 来 介绍 如 何 实现 对 数据 表 中 记录 的 插入 、 浏 览 、 修 改 及 删除 操作 。 认 真 学 过 本 节 内 容 后 ， 
读者 能 对 如 何 操作 数据 表 有 一 个 充分 的 认识 


m) 


(0 pHP 网 络 编程 技术 详解 


14.4.1 执行 INSERT INTO 语句 插入 记录 


GEH 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 14 章 \ 执 行 INSERT INTO 语句 插入 记录 .wmv 
一 个 表 在 创建 之 后 是 没有 任何 记录 的 ， 只 有 在 表 中 插入 记录 才能 发 挥 表 的 作用 。 要 对 表 中 插入 记 
录 ， 可 以 使 用 mysql_query() 函 数 发 送 SQL 请 求 。SQL 语句 的 内 容 如 下 所 示 : 


insert into table_name(field01,field02…) values(values1,value2…) 


其 中 table_name 是 表 的 名 称 ，field01、field02 是 指 表 的 字段 名 称 ，values1、values2 是 指 想 要 插入 
记录 中 对 应 字段 的 值 。 
假如 有 名 为 testl 的 表 ， 它 的 结构 如 下 所 示 : 


id int(5) not null auto_increment primary key, 
name varchar(12) not null, 

mail varchar(30) not null, 

phone varchar(14) not null, 

address varchar(30) not null 


可 以 看 出 ， 该 表 有 5 列 CBD . 4394 ID GAS) NAME (名 称 ) MAIL (电子 信箱 〉、 
PHONE (电话 ) ~ ADDRESS 地址 ) 。 如 果 想 要 把 名 字 为 “ 张 三 ” 的 记录 插入 test! KP, MIZA 
行 这 样 的 操作 : 

insert into test1(name,mail,phone,address) values(" 张 三 ","zhangsan@homail.com""1234567"," 某 省 某 市 某 区 某 街 ") 

为 什么 没有 给 ID 赋值 ? 因为 字段 ID 为 关键 字段 ， 并 且 具 有 自动 增加 1 的 属性 ， 所 以 不 用 为 其 单 
独 赋 值 。 第 一 条 记录 的 ID 号 自动 为 1， 以 后 每 插入 一 条 ，ID 号 就 会 自动 向 后 增加 。 

【实例 14-7】 以 下 代码 把 以 上 的 分 析 归 结 到 实例 中 执行 一 下 ， 以 检测 能 否 正确 插入 记录 (在 执行 
前 ， 请 确保 test 库 中 有 test] 这 个 表 ) 。 


re 实例 14-7. 检测 能 否 正确 插入 记录 
e 源码 路 径 ， 光盘 \ 源 文件 \14\14-7.php 


01 <html> 

02 <head> 

03 ”<title> 在 表 中 插入 记录 </title> 

04 </head> 

05 <body> 

06 <?php 

07 $db host-"localhost"; /MySQL 服务 器 名 

08 $db user-"root"; IIMySQL 用 户 名 

09 $db_pass="admin"; /MySQL 用 户 对 应 密码 

10 $db_name="test"; // 要 操作 的 数据 库 

11 // 使 用 mysql_connect() 函 数 对 服务 器 进行 连接 ， 如 果 出 错 ， 则 返回 相应 信息 

12 $link=mysql_connect($db_host,$db_user,$db_pass)or die(" 不 能 连接 到 服务 器 ".mysql_error()); 
13 mysql select db($db name,Slink); /选择 相应 的 数据 库 ， 这 里 选择 test Æ 

14 $sgl-"select * from test1"; // 先 执行 SQL 语句 显示 所 有 记录 以 与 插入 后 相 比较 
15 $result=mysql_query($sql,$link); /使 用 mysql_query() 函 数 发 送 SQL 请 求 


16 echo "当前 表 中 的 记录 有 : "; 
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17 echo "<p>"; 
18 while($row-mysql fetch array(Sresult)) Ia SQL 语句 执行 结果 ， 把 值 赋 给 数组 
19 { 
20 echo $row[id].”", "; // 显 示 ID 
21 echo $row[name'.", "; /显示 姓名 
22 echo $row[mail'.", "; /显示 邮箱 
23 echo $row[phone].", "; /显示 电话 
24 echo $row|'address').", "; /显示 地 址 
25 echo "<p>"; 
26 ) 
27 MAR SQL 语句 为 插入 记录 操作 
28 $sql="insert into test1(name,mail,phone,address) values(' 3K = ','zhangsan(ghomail.com', 
"1234567",' 某 省 某 市 某 区 某 街 )"; 
29 if(mysql query($sql)) // 判 断 并 执行 SQL 语句 
30 echo "记录 已 经 成 功 插 入 "; 
31 echo "<p>"; 
32 $sql="select * from test1"; // 先 执行 SQL 语句 显示 所 有 记录 以 与 插入 后 相 比 较 
33 $result=mysql_query($sql, $link); /使 用 mysql_query() 函 数 发 送 SQL 请 求 
34 echo "当前 表 中 的 记录 有 : "; 
35 echo "<p>"; 
36 while($row-mysql fetch array(Sresult)) /再 次 遍历 结果 
37 { 
38 echo $row[id"].", "; /显示 ID 
39 echo $row[name]"，"; /显示 姓名 
40 echo $row[mail].", "; /显示 邮箱 
41 echo $row['phone].", "; /显示 电话 
42 echo $row[address'.", "; // 显 示 地 址 
43 echo "«p»"; 
44 ) 
45 ?> 
46 </body> 
47 «html» 
在 PHP 运行 环境 下 执行 该 PHP 文件 ， 执 行 结 果 如 图 14.7 Bras. 
[Eu] 
ET 
当前 表 中 的 记录 在 : ^ 
记录 已 经 成 功 插入 
当前 表 中 的 记录 让 : 
1, REG changonghomaileom, 1231567, XA OERAIERS, | 
uo - 


图 14.7 在 表 中 插入 记录 执行 结果 


通过 图 14.7 可 以 看 到 ， 在 第 一 次 对 表 进 行 浏览 操作 时 ， 由 于 没有 任何 记录 ， 所 以 并 没有 任何 值 返 
回 。 当 执行 完 SQL 语句 后 再 对 表 进 行 遍历 时 就 有 了 一 条 记录 ， 并 且 显 示 出 了 记录 的 内 容 。 说 明 在 表 中 
顺利 插入 了 一 条 记录 。 

下 面 对 以 上 实例 中 相关 的 一 些 函 数 作用 做 一 简单 的 介绍 。 

mysql_fetch_array() 函 数 : 返回 根据 从 结果 集 取得 的 行 生成 的 数组 。 


(0 PHPBRABGUE BURG 


以 上 实例 中 执行 了 SELECT 查询 ， 对 表 的 内 容 进行 浏览 ， 结 果 保 存 到 $result， 而 使 用 


mysql_fetch_array0 函 数 将 返回 根据 从 $result 取得 的 行 生成 一 个 数组 。 


14. 


4.2 执行 SELECT 查询 


[zl 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 14 章 \ 执 行 SELECT 查询 .wmv 
显示 表 中 的 内 容 ， 或 者 对 表 中 特定 内 容 进 行 搜索 时 都 需要 对 表 进 行 查询 。 所 以 对 表 的 查询 操作 也 


是 用 得 最 多 的 SQL 命令 之 一 。 对 表 中 记录 进行 浏览 要 使 用 mysql_query0 函 数 发 送 SQL 请 求 。 查 询 是 
使 用 最 多 的 SQL 命令 。 查 询 数据 库 需 要 凭借 结构 、 索 引 和 字段 类 型 等 因素 。SELECT 查询 的 基本 语法 
如 下 所 示 : 


SELECT [STRAIGHT JOIN] [SQL_ SMALL RESULT][SQL BIG RESULT] [HIGH PRIORITY] 
[DISTINCT | DISTINCTROW | ALL] 

select expression,... 

[INTO (OUTFILE | DUMPFILE) 'file name' export options] 

[FROM table references 

][WHERE where definition] 

[GROUP BY col name....] 

[HAVING where definition] 

[ORDER BY (unsigned integer | col name | formula) J|ASC | DESC]....] 
[LIMIT ][offset] rows] 

[PROCEDURE procedure name]] 


很 多 语法 暂时 还 用 不 到 ， 以 后 在 高 级 查询 中 专门 为 读者 讲解 ， 现 在 只 是 要 浏览 表 中 所 有 的 记录 ， 


只 需要 使 用 : 


select * from tablename 


tx 号 表示 所 有 内 容 ， 所 以 这 一 句 表示 查询 tablename 表 中 的 所 有 记录 。 这 在 14.4.1 小 节 对 数据 


表 插入 记录 时 已 经 见 到 过 。 
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【实例 14-8】 以 下 代码 演示 如 何 使 用 SELECT 查询 获得 表 中 的 记录 。 
区 < | 如 何 使 用 SELECT 查询 获得 表 中 的 j 录 ——000— 


-| 源码 路 径 ， 光盘 \ 源 文件 \14\14-8.php 

01 <html> 

02 «head» 

03 ”<title> 浏 览 表 中 记录 </title> 

04 </head> 

05 <body> 

06 <center> 

07 <?php 

08 $db host-'localhost"; /MySQL 服务 器 名 

09 $db user-'root"; /MySQL Ri P: 

10 $db pass-"admin"; IIMySQL 用 户 对 应 密码 

11 $db_name="test"; // 要 操作 的 数据 库 

12 /使 用 mysql_connect() 函 数 对 服务 器 进行 连接 ， 如 果 出 错 ， 则 返回 相应 信息 
13 S$linkzmysql connect($db host,$db user,$db pass)or die(" 不 能 连接 到 服务 器 ".mysql_error()); 


sus gams eee 


14 mysql_select_db($db_name, $link); /选择 相应 的 数据 库 ， 这 里 选择 test HE 
15 $sql="select* from test1"; // 先 执行 SQL 语句 显示 所 有 记录 以 与 插入 后 相 比 较 
16 $result-mysgl guery($sgi, $link); /使 用 mysql_query() 函 数 发 送 SQL 请 求 
17 echo "当前 表 中 的 记录 有 : "; 
18 echo "<table border=1>"; /使 用 表格 格式 化 数据 
19 echo "<tr><td>ID</td><td> 姓 名 </td><td> 邮 箱 </td><td> 电 话 </td><td> 地 址 </td></tr>"; 
20 while($row=mysql_fetch_array($result)) /遍历 SQL 语句 执行 结果 ， 把 值 赋 给 数组 
21 f 
22 echo "<tr>"; 
23 echo "«td»" Srow['id']."«/td»"; // 显 示 ID 
24 echo "<td>".$row[name]." </td>"; /| 显示 姓名 
25 echo "<td>".$row['mail]." </td>"; /显示 邮箱 
26 echo "<td>".$row| phone')." </td>"; /显示 电话 
27 echo "«td»" $row[ address?" </td>"; /显示 地 址 
28 echo "</tr>"; 
29 ) 
30 echo "</table>"; 
31 ?» 
32 </center> 
33 </body> 
34 </html> 
在 PHP 运行 环境 中 执行 该 PHP 文件 ， 执 行 结果 如 图 14.8 所 示 。 
Ce 
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图 14.8 浏览 表 中 记录 执行 结果 
14.4.3 ”使 用 表单 扩展 添加 记录 功能 
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虽然 INSERT INTO 是 执行 添加 记录 操作 的 核心 ， 但 总 不 能 插入 一 条 记录 就 把 实例 14-7 中 的 内 容 
修改 一 次 。 所 以 应 该 采用 互动 的 形式 ， 用 户 输入 什么 数据 ， 就 插入 相应 的 记录 。 本 小 节 把 前 两 小 节 的 
内 容 结合 起 来 ， 再 利用 Web 表单 ， 实 现 用 户 输入 记录 的 添加 ， 来 做 一 个 简易 的 通讯 录 。 其 中 的 表 还 使 
用 test 库 中 的 testl 表 。 

显示 记录 的 页 面 ， 只 需要 把 实例 14-8 作 简 单 修改 即 把 标题 修改 后 并 加 入 指向 添加 记录 前 台 〈 实 
例 14-9 的 代码 ) 连接 即 可 。 

【实例 14-9】 下 面 制作 添加 记录 的 前 台 ， 主 要 是 使 用 了 Web 表单 ， 并 把 form 的 action 属性 指向 
目标 页 面 即 可 。 

E < | 实例 14-9. 添加 记录 的 前 台 

源码 路 径 光盘 \ 源 文件 \14\14-9.php 
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02 «head» 

03 ”<title> 简 易 通 讯 录 添加 记录 前 台 </title> 

04 </head> 

05 <body> 

06 «script language="javascript"> 

07 function Juge(theForm) 

08 i 

09 if (theForm.name.value == "") 

10 

11 alert(" 请 输入 姓名 ! "); 

12 theForm.name.focus(); 

13 return (false); 

14 y 

15 if (theForm.phone.value == "") 

16 { 

17 alert(" 请 输入 电话 号 码 ! "); 

18 theForm.phone.focus(); 

19 return (false); 

20 ) 

21 if (theForm.address.value == "") 

22 ( 

23 alert(" 请 输入 地 址 ! "); 

24 theForm.address.focus(); 

25 return (false); 

26 ) 

27 ) 

28 «script» 

29 «center» 

30 <h1> 简 易 通讯 录 添加 记录 前 台 </h1> 

31 <p> 

32 <a href="14-10.php"> 返 回首 页 </a> 

33 <table border=1> 

34 «form action="14-12.php" method="post" onsubmit="return Juge(this)"> 
35 <tr> 

36 <td> 输 入 姓名 : </td> 

37 «td» «input name="name" type="text"></td> 
38 «ftr» 

39 <tr> 

40 <td> 输 入 邮箱 : </td> 

41 «td» «input name="mail" type="text"></td> 
42 «ftr» 

43 <tr> 

44 <td> 输 入 电话 : </td> 

45 «td» «input name-"phone" type="text"></td> 
46 «itr» 

47 <tr> 

48 <td> 输 入 地 址 : </td> 

49 <td><input name-"address" type-"text"» «/td» 
50 «itr» 

51 <tr> 

52 «td colspan="2"><center><input type=submit value=" 确 认 提交 "> 


第 14 章 SEMSQLÉGEE ©) 


53 «input type-reset value=" 重 新 选择 "></center></td> 
54 «ltr» 

55 </form> 

56 </table> 

57 </center> 

58 </body> 

59 </html> 


最 后 制作 对 输入 记录 的 后 台 处 理 页 面 。 添 加 记录 的 核心 还 是 使 用 INSERT INTO 这 样 一 条 SQL if 
句 ， 把 记录 插入 表 中 。 
【实例 14-10】 以 下 代码 演示 如 何 获取 表单 输入 的 数据 ， 并 把 记录 存 入 注册 表 ， 这 是 实现 与 用 户 
互动 的 关键 技术 。 
区 "" | 实例 14-10: 获取 表单 输入 的 数据 ， 并 把 记录 存 入 注册 表 
源码 路 径 : 光盘 \ 源 文件 \14\14-10.php 


01 <?php 
02 /* 下 面 内 容 为 获取 表单 输入 ， 并 去 掉 HTML 格式 。 
03 由 于 表单 采用 post 方式 传递 数据 ， 所 以 用 post 来 获取 输入 */ 


04 $name=htmlspecialchars($_POST[name]); /| 获取 姓名 

05 $mail-htmlspecialchars($ POST[mail'); // 获 取 邮 箱 

06 $phone-htmlspecialchars($ POST[phone']); /获取 电话 

07 $address=htmlspecialchars($_POST[address']); /获取 地 址 

08 $db_host="localhost"; /MySQL 服务 器 名 

09 $db_user="root"; /MySQL 用 户 名 

10 $db_pass="admin"; /MySQL 用 户 对 应 密码 
11 $db name-"test"; // 要 操作 的 数据 库 

12 $table namez"test1"; IRZ 

13 $myconn=mysql_connect("$db_host","$db_user","$db_pass"); // 连 接 服务 器 
14 mysql_select_db($db_name,$myconn); /| 选择 操作 库 

15 $strSql="insert into $table name(name,mail,phone,address) values ('$name',$mail', '$phone', 
'Saddress')"; // 对 表 进 行 插入 操作 

16 mysql_query($strSql,$myconn) or die(" 插 入 时 出 错 ".mysql_error()); /发 送 SQL 请 求 
(112052 

18 «html» 

19 <head> 

20 ”<title> 简 易 通 讯 录 添加 记录 处 理 </title> 

21 </head> 

22 <meta http-equiv="refresh" content="2; url=14-8.php"> 

23 <body> 

24 ”已 经 成 功 添 加 记录 ， 两 秒 后 返回 。 

25 </body> 

26 </html> 


至 此 ， 整 个 简易 通讯 录 程序 就 算是 制作 完毕 了 。 到 底 能 否 实现 ， 手 动 输入 记录 信息 ， 并 把 记录 插 
入 表 中 呢 ? 下 面 就 来 运行 一 下 整个 程序 ， 看 执行 结果 。 

首先 运行 修改 后 的 实例 14-8， 执 行 结果 如 图 14.9 所 示 。 

从 图 14.9 的 执行 结果 可 见 ， 显 示 出 了 原 有 的 数据 〈 这 个 数据 是 在 前 面 讲 的 内 容 中 添加 的 ) 。 接 下 
来 ， 单 击 “添加 记录 ”链接 ， 相 当 于 执行 实例 14-9。 单 击 链接 后 的 结果 如 图 14.10 所 示 。 
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10% ~ LINE 
14.9 简易 通讯 录 显示 数据 页 执行 结果 图 14.10 简易 通讯 录 添加 记录 前 台 执 行 结果 
由 于 表 中 记录 只 有 5 项 ,而 ID 一 项 还 是 主键 并 且 具 有 自动 增加 的 属性 。 所 以 不 必 为 其 添加 值 。 只 


需要 输入 图 14.11 所 示 的 4 项 内 容 即 可 。 按 照 提 示 输 入 相应 的 信息 。 这 里 输入 以 下 简单 信息 : 李 四 、 
lisi@mircosoft.com、2345678、 北 京 市 海淀 区 《〈 读 者 也 可 以 根据 自己 需要 输入 合适 的 信息 ) 。 输 入 完 后 
单 击 “ 确 认 提交 ”按钮 ， 将 转 到 实例 14-10。 

而 实例 14-10 只 对 数据 进行 了 处 理 ， 马 上 又 自动 跳 转 到 了 实例 14-8， 如 图 14.11 所 示 。 
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图 14.11 插入 后 的 数据 显示 页 结果 


通过 图 14.11 可 见 ， 显示 的 记录 中 在 原 有 的 张 三 后 ,又 显示 了 刚刚 插入 的 李 四 的 记录 ,说明 记 录 已 
经 被 插入 数据 库 之 中 。 该 简易 通讯 录 程 序 测试 通过 。 


14.4.4 执行 UPDATE 语句 更 新 记录 


EB 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 14 章 \ 执 行 UPDATE 语句 更 新 记录 .wmv 

记录 在 入 库 后 ， 并 不 是 一 成 不 变 的 ， 有 时 可 能 需要 对 某 些 内 容 作 相应 的 调整 ， 这 时 就 要 用 到 
UPDATE 语句 对 记录 进行 更 新 。UPDATE 语句 的 使 用 格式 如 下 : 

update table name set field01="value1",field02="value02" where where definition 

其 中 的 table_name 为 欲 操作 的 表 名 ，field01、field02 为 字段 名 ， 而 后 面 的 valuel. value? 为 想 要 
更 改 为 的 内 容 。 后 面 的 where_definition 为 更 改 源 记 录 的 条 件 。 如 想 把 testl 表 中 张 三 的 记录 改 为 王 五 的 ， 
可 以 执行 这 样 的 操作 : 

update test! set name=" 王 五 ",mail="wangwu@tom.com",phone="3456789",address=" 上 海 市 高 新 开发 区 " 

where name=" 张 三 "; 
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后 面 的 where name=" 张 三 "如 果 改 成 id=1 会 更 合适 。 因 为 字段 id 是 主键 ,并 且 具 有 唯一 性 ， 所 以 


不 可 能 出 现 寻 


E. 而 name 则 不 一 样 , 如 果 有 重 名 的 “ 张 三 ” 则 执行 相应 的 操作 会 把 所 有 的 都 进行 更 新 。 


【实例 14-11】 以 下 代码 演示 如 何 使 用 UPDATE 语句 来 更 改 已 经 存在 的 记录 。 


实例 14-11: 如 何 使 用 UPDATE 语句 来 更 改 已 经 存在 的 记录 
源码 路 径 : 光盘 \ 源 文件 \14\14-11.php 


01 «html» 

02 <head> 

03 ”<title> 更 改 表 中 记录 </title> 

04 </head> 

05 <body> 

06 <center> 

07 <?php 

08 $db_host="localhost"; IIMySQL 服务 器 名 

09 $db_user="root"; /MySQL 用 户 名 

10 $db_pass="admin"; /MySQL 用 户 对 应 密码 

11 $db_name="test"; // 要 操作 的 数据 库 

12 /使 用 mysql_connect() 函 数 对 服务 器 进行 连接 ， 如 果 出 错 ， 则 返回 相应 信息 

13 $link=mysql_connect($db_host,$db_user,$db_pass)or die(" 不 能 连接 到 服务 器 ".mysql_error()); 
14 mysql_select_db($db_name,$link); /| 选择 相应 的 数据 库 ， 这 里 选择 test 库 

15 function show_con() // 把 显示 记录 功能 做 成 函数 以 便 多 次 调用 
16 { 

17 $link=mysql_connect(localhost ,root,admin'); 

18 mysql select db(test); 

19 $sql-"select * from test1"; // 先 执行 SQL 语句 显示 所 有 记录 以 与 更 改 后 相 比较 
20 $result=mysql_query($sql,$link); /使 用 mysql_query() 函 数 发 送 SQL 请 求 
21 echo "<table border- 12"; /使 用 表格 格式 化 数据 

22 echo "<tr><td>ID</td><td> 姓 名 </td><td> 邮 箱 </td><td> 电 话 </td><td> 地 址 </td></tr>"; 
23 while($row-mysql fetch array($result)) NBA SQL 语句 执行 结果 ， 把 值 赋 给 数组 
24 { 

25 echo "<tr>"; 

26 echo "«td»" $row['id']."«/td»"; /显示 ID 

27 echo "<td>".$row[name]." </td>"; /显示 姓名 

28 echo "<td>".$row['mail]." </td>"; /显示 邮箱 

29 echo "«td»".$row[phone." </td>"; /显示 电话 

30 echo "«td»".$row['address']." </td>"; /显示 地 址 

31 echo "</tr>"; 

32 ) 

38 echo "</table>"; 

34 H 

35 echo "更 新 前 的 记录 为 : "; 

36 show con(); // 调 用 函数 ， 显 示 表 中 所 有 记录 

37 $sql="update test set name-' XE i',mail-wangwu(gttom.com',phone-'3456789'address-' Ej 
市 高 新 开发 区 ' where id-1"; /创建 更 新 记录 SQL 语句 

38 mysql query($sql.Slink); /发 送 SQL 请 求 

39 echo "更 新 后 的 记录 为 :"; 

40 show con(); /再 次 调用 函数 ， 显 示 表 中 记录 以 做 比较 
41 ?> 

42 </center> 
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43 </body> 
44 </html> 


在 PHP 运行 环境 下 执行 该 PHP 文件 ， 执 行 结果 如 图 14.12 所 示 。 
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图 14.12 更改 表 中 记录 执行 结果 


从 图 14.12 可 以 看 到 在 执行 更 新 数据 操作 之 前 ,调用 显示 记录 函数 返回 的 第 一 条 记录 为 张 三 。 而 执 
行 完 更 新 操作 后 ， 再 次 调用 显示 记录 函数 ， 返 回 的 第 一 条 记录 已 经 成 了 王 五 ， 说 明 顺 利 地 把 表 中 记录 


号 为 1 的 记录 进行 了 更 改 。 
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就 像 插入 记录 操作 一 样 ， 不 可 能 每 更 改 一 条 记录 就 修改 一 次 实例 14-11 中 的 内 容 ， 并 执行 一 次 该 
PHP 文件 。 如 果 能 与 Web 表单 结合 起 来 ， 实 现 用 户 输入 什么 内 容 ， 就 更 改 什么 内 容 ， 那 样 就 会 方便 很 
多 。 下 面 就 来 介绍 ， 如 何 使 用 Web 表单 与 更 改 数据 记录 的 操作 结合 起 来 。 

【实例 14-12】 以 下 代码 把 14.4.2 小 节 所 制作 的 显示 记录 文件 作 简单 的 修改 。 


01 «html» 

02 <head> 

03 ”<title> 浏 览 表 中 记录 </title> 

04 </head> 

05 «body» 

06 <center> 

07 <?php 

08 $db. host-"localhost"; IIMySQL 服务 器 名 

09 $db user-'root"; /MySQL 用 户 名 

10 $db pass-"admin"; /MySQL 用 户 对 应 密码 

11 $db name-'test"; // 要 操作 的 数据 库 

12 // 使 用 mysql_connect() 函 数 对 服务 器 进行 连接 ， 如 果 出 错 ， 则 返回 相应 信息 

13 $link=mysql_connect($db_host,$db_user,$db_pass)or die(" 不 能 连接 到 服务 器 ".mysql_error()); 
14 mysql select db($db name,Slink); /选择 相应 的 数据 库 ， 这 里 选择 test Æ 

15 $sql="select * from test1"; // 先 执行 SQL 语句 显示 所 有 记录 以 与 插入 后 相 比较 
16 $result=mysql_query($sql,$link); /使 用 mysql_query() 函 数 发 送 SQL 请 求 


17 echo "当前 表 中 的 记录 有 : "s 
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18 echo "<table border=1>"; /使 用 表格 格式 化 数据 

19 echo "<tr><td>ID</td><td> 姓 名 </td><td> 邮 箱 </td><td> 电 话 </td><td> 地 址 </td><td>&nbsp; </td> </tr>"; 
20 while($row=mysql_fetch_array($result)) /遍历 SQL 语句 执行 结果 ， 把 值 赋 给 数组 
21 { 

22 echo "<tr>"; 

23 echo "«td»" $row[id']."«/td»"; /显示 ID 

24 echo "<td>".$row[name]." </td>"; /显示 姓名 

25 echo "«td»" $row[mail']." </td>"; /显示 邮箱 

26 echo "<td>".$row| phone')." </td>"; /显示 电话 

27 echo "<td>".$row['address]." </td>"; /显示 地 址 

28 echo "<td><a href='14-15.php?id=".$row['id]."> 修 改 </a></td>"; 

29 echo "</tr>"; 

30 ) 

31 echo "</table>"; 

32 ?> 

33 </center> 

34 </body> 

35 </html> 


可 以 看 出 ， 与 实例 14-8 不 同 的 是 ， 为 显示 的 表格 增加 了 一 列 ， 列 中 显示 指向 修改 记录 前 台 页 面 的 
连接 。 

【实例 14-13】 以 下 代码 为 修改 记录 的 前 台 页 面 。 该 页 面 与 实例 14-9 的 前 台 基 本 相似 , 不 同 的 是 ， 
由 于 是 修改 已 经 存在 的 记录 ， 所 以 要 能 显示 原 有 的 记录 内 容 。 


Uu 实例 14-13; 修改 记录 的 前 台 页 面 
源码 路 径 : 光盘 \ 源 文件 \14\14-13.php 


01 «html» 

02 <head> 

03 ”<title> 简 易 通 讯 录 修改 记录 前 台 </title> 

04 </head> 

05 <body> 

06 <script language="javascript"> 

07 function Juge(theForm) 

08 { 

09 if (theForm.name.value == "" 
10 { 

11 alert(" 请 输入 姓名 ! "); 
12 theForm.name.focus(); 
13 return (false); 

14 

15 if (theForm.phone.value == "" 
16 { 

17 alert(" 请 输入 电话 号 码 ! "); 
18 theForm.phone.focus(); 
19 return (false); 

20 

21 if (theForm.address.value == "" 
22 { 

23 alert(" 请 输入 地 址 ! "); 


PHP 网 络 编程 技术 详解 

24 theForm.address.focus(); 

25 return (false); 

26 ) 

27 ) 

28 «Iscript» 

29 «center» 

30 <h1> 简 易 通 讯 录 修改 记录 前 台 </h1> 

31 <p> 

32 <a href="14-14.php"> 返 回首 页 </a> 

33 <table border=1> 

34 «form action="14-16.php" method="post" onsubmit="retum Juge(this)"» 

35 «?php 

36 Slinkemysql connect("localhost","root","admin"); 

37 mysql select db(test' $link); /选择 相应 的 数据 库 ， 这 里 选择 test Æ 
38 $sql-"select * from test where id-".$ GET[id']; /只 显示 请 求 ID 号 的 内 容 
39 $result=mysql_query($sql); 

40 $row=mysql_fetch_array($result); /把 结果 赋值 给 数组 

41 ?> 

42 <input type="hidden" name="id" value="<?echo $row[id]?>"> 

43 <tr> 

44 <td> 输 入 姓名 : </td> 

45 <td><input name="name" type="text" value="<?php echo $row[name]?>"></td> 
46 «ftr» 

47 <tr> 

48 <td> 输 入 邮箱 : </td> 

49 <td><input name="mail" type="text" value="<?php echo $row['mail]?>"></td> 
50 «tr 

51 <tr> 

52 <td> 输 入 电话 : </td> 

53 <td><input name="phone" type="text" value="<?php echo $row['phone']?>"> 
</td> 

54 </tr> 

55 <tr> 

56 <td> 输 入 地 址 : </td> 

57 <td><input name-"address" type="text" value="<?php echo $row['address]?>"> 
</td> 

58 </tr> 

58 <tr> 

59 «td colspan="2"><center><input type=submit value=" 确 认 提交 "> 

60 «input type=reset value=" 重 新 选择 "></center></td> 

61 «itr» 

62 </form> 

63 </table> 

64 </center> 

65 </body> 

66 </html> 

可 以 看 出 , 上 面 代码 与 实例 14-8 的 不 同 , 就 是 多 了 一 项 从 表 中 查找 出 想 要 修改 的 记录 的 原始 内 容 ， 


并 把 相应 
作为 提交 


282 


的 值 赋 给 相应 的 表单 元 素 。 同 时 ， 该 表单 中 多 了 一 个 隐藏 的 表单 元 素 ID， 它 指向 记录 的 ID, 
表单 并 且 修 改 记录 的 条 件 。 
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【实例 14-14】 以 下 代码 为 修改 记录 的 后 台 操 作 页 面 。 
区 a 实例 14-14. 修改 记录 的 后 台 操作 页 面 
源码 路 径 : 光盘 \ 源 文件 \14\14-14.php 


01 <?php 
02 /* 下 面 内 容 为 获取 表单 输入 ， 并 去 掉 HTML 格式 。 
03 由 于 表单 采用 post 方式 传递 数据 ， 所 以 用 post 来 获取 输入 */ 


04 $name=htmlspecialchars($_POST[name]); /获取 姓名 

05 $mail-htmlspecialchars($ POST[mail'); /获取 邮箱 

06 $phone-htmlspecialchars($ POST['phone']); /获取 电话 

07 $address-htmlspecialchars($ POST[address']; /获取 地 址 

08 $id=$_POST[id]; /获取 ID 

09 $db hostz"localhost"; IIMySQL 服务 器 名 

10 $db user-'root"; IIMySQL 用 户 名 

11 $db_pass="admin"; IIMySQL 用 户 对 应 密码 

12 $db_name="test"; // 要 操作 的 数据 库 

13 S$table_name="test1"; NRB 

14 $myconn=mysql_connect("$db_host","$db_user","$db_pass"); /| 连接 服务 器 
15 mysql_select_db("$db_name",$myconn); /| 选择 操作 库 

16 $strSql="update $table name set name='$name',mail='$mail',phone='$phone',address='$address' 
where id=$id"; // 对 表 进 行 修改 操作 

17 mysql_query($strSql,$myconn) or die(" 插 入 时 出 错 ".mysql_error()); /发 送 SQL 请 求 
18 ?> 

19 <html> 

20 <head> 

21 «html» 

22 <head> 

23 ”<title> 简 易 通讯 录 修 改 记录 处 理 </title> 

24 </head> 

25 <meta http-equiv="refresh" content="2; url=14-12.php"> 

26 <body> 

27 ”已 经 成 功 修改 记录 ， 两 秒 后 返回 。 

28 </body> 

29 </html> 


可 以 看 出 以 上 代码 与 实例 14-10 也 基本 类 似 ， 除 了 SQL 语句 内 容 有 所 不 同 ， 其 他 地 方 都 相同 。 
这 3 个 文件 创建 完毕 ,开始 测试 更 改 功能 是 否 起 作用 。 第 一 步 先 在 PHP 运行 环境 中 执行 实例 14-12， 
执行 结果 如 图 14.13 所 示 。 


LESS ESSERE RE [EE S] 
Bose jeza 


Aue v 


图 14.13 浏览 表 中 记录 带 修改 连接 执行 结果 
从 图 14.13 可 以 看 出 与 图 14.9 的 不 同 之 处 就 在 于 表格 多 出 一 列 “修改 ”的 链接 。 单 击 “ 修 改 ” 链 


所 示 。 


这 回首 页 
AER. [za 
CIE TTE 
入 电话 ，||3456789 

入 地 址 ，|| 上海 市 高 新 开发 区 
确认 提交 || 重新 选择 


图 14.14 ”简易 通讯 录 修 改 记录 前 台 执 行 结果 
从 图 14.14 可 以 看 出 , 连接 到 此 页 , 显示 出 了 原来 存在 的 记录 的 内 容 。 下面 对 该 记录 进行 适当 修改 。 
为 了 便于 对 照 ， 只 把 其 中 的 电话 由 3456789 改 为 1234567; 把 上 海 市 高 新 开发 区 ， 修 改 为 上 海 市 南京 路 
(读者 也 可 以 根据 自己 的 需要 进行 相应 的 修改 ) ; 其 他 内 容 保持 不 变 。 输 入 相应 内 容 后 ， 单 击 “ 确 认 
提交 ”按钮 。 将 跳 转 到 实例 14-14 对 数据 进行 处 理 ， 执 行 结果 如 图 14.15 所 示 。 


[€] [S hevos P ~ O | S namen 
| 当前 表 中 的 记录 有 ， 
中 隆 名 | 邮箱 [EN 53 


1 EE wangungitom con: [1234567] EX i $8 ev] 
[2 EEFS|lisiimircosos com|p345678| Us PRERE] 


图 14.15 ”修改 记录 后 台 处 理 执行 结果 
由 于 实例 14-14 使 用 了 页 面 自动 跳 转 ， 所 以 在 执行 完 修改 记录 操作 后 ， 直 接 跳 转 到 了 实例 14-12。 
不 过 ， 比 较 图 14.13 与 图 14.15 可 以 发 现 ，ID 号 为 1 的 记录 中 的 电话 号 码 和 地 址 都 已 经 发 生 了 改变 ， 
由 原来 的 内 容 变 成 了 对 图 14.14 修改 后 的 内 容 ， 说 明 对 数据 的 重新 记录 操作 顺利 执行 。 
如 果 把 本 小 节 所 介绍 的 内 容 与 14.4.3 小 节 所 介绍 的 功能 结合 起 来 ， 就 是 一 个 功能 完善 〈 添 加 记录 、 
修改 记录 ) 的 简易 通讯 录 程 序 了 。 


14.4.6 ”执行 DELETE 语句 删除 记录 


YA 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 14 3E UT DELETE 语句 删除 记录 .wmv 

数据 表 中 的 内 容 如 果 不 再 需要 ， 为 了 节省 空间 ， 把 多 余 的 记录 从 表 中 删除 是 有 必要 的 。 本 小 节 为 
读者 介绍 如 何 删除 表 中 的 记录 。 

要 想 删 除 表 中 不 再 需要 的 记录 ， 可 以 使 用 mysql_query0 函 数 发 送 一 条 DELETE 的 SQL 语句 。 
DELETE 的 使 用 语法 如 下 所 示 : 

delete from table name where t field01="value1" 


其 中 的 table name 为 欲 删 除 的 记录 所 在 的 表 名 ， 后 面 的 where 子 句 表示 执行 操作 的 条 件 ，field01 
指 字段 名 , valuel 指 对 应 于 字段 field01 的 值 。 如 想 把 test] 表 中 王 五 的 记录 删除 , 可 以 执行 这 样 的 操作 : 


(m, 
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delete from test1 where t name-" FA" 


正如 14.44 小 节 提 到 的 那样 ， 字 段 ID 是 表 testl 的 主键 ， 并 且 具 有 唯一 性 。 所 以 如 果 把 上 面 代 码 


中 的 name=" 王 五 "更 改 为 id=1 会 更 好 地 执行 操作 。 


【实例 14-15】 以 下 代码 演示 如 何 使 用 DELETE 语句 来 删除 已 经 存在 且 不 再 需要 的 记录 。 


|. | 实例 14-15: 如 何 使 用 DELETE 语句 来 删除 已 经 存在 且 不 再 需要 的 记录 
源码 路 径 光盘 \ 源 文件 \14\14-15.php 


<head> 

<title> 删 除 表 中 记录 </title> 

</head> 

<body> 

<center> 

<?php 
// 使 用 mysql_connect() 函 数 对 服务 器 进行 连接 ， 如 果 出 错 ， 则 返回 相应 信息 
$link=mysql_connect("localhost","root","admin")or die(" 不 能 连接 到 服务 器 ".mysql_error()); 


mysq| select db(test' Slink); /| 选择 相应 的 数据 库 ， 这 里 选择 test Æ 
function show con() /把 显示 记录 功能 做 成 函数 以 便 多 次 调用 
{ 


$link=mysql_connect(localhost ,root,"admin"); 
mysql_select_ db(test'); 


$sql-"select * from test1"; // 先 执行 SQL 语句 显示 所 有 记录 以 与 更 改 后 相 比 较 
$result=mysql_query($sql,$link); /使 用 mysql_query() 函 数 发 送 SQL 请 求 
echo "<table border=1>"; /使 用 表格 格式 化 数据 


echo "<tr><td>ID</td><td> 姓 名 </td><td> 邮 箱 </td><td> 电 话 </td><td> 地 址 </td></tr>"; 
while($row=mysql_fetch_array($result)) /遍历 SQL 语句 执行 结果 ， 把 值 赋 给 数组 


{ 
echo "<tr>"; 
echo "«td»" $row['d']."/td»"; /显示 ID 
echo "«td»".$row[name']" </td>"; /显示 姓名 
echo "<td>".$row[mail]." </td>"; ”// 显 示 邮 箱 
echo "«td»".$row[phone'." </td>"; /显示 电话 
echo "«td»" $row['address']." </td>"; // 显 示 地 址 
echo "</tr>"; 

} 

echo "</table>"; 


} 
echo "删除 前 的 记录 为 :"; 
show con(); // 调 用 函数 ， 显 示 表 中 所 有 记录 
$sql="delete from test1 where id=1"; // 创 建 更 新 记录 SQL 语句 
mysql_query($sql,$link); // 发 送 SQL 请 求 
echo "<p>"; 
echo "删除 后 的 记录 为 :"; 
show con(); // 再 次 调用 函数 ， 显 示 表 中 记录 以 做 比较 
?» 
</center> 
</body> 
</html> 
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在 PHP 运行 环境 下 执行 该 PHP 文件 ， 执 行 结果 如 图 14.16 所 示 。 


[EE [ean Gites com |1234567|| 上 海 市 南京 路 | 
Fisi d mircosoft com|2345674|| 北 永 市 海淀 区 | 
删除 后 的 记录 为 : 
WA 电话 | 好 址 

[2 | 医 四 |isi@mircosof com|234567:| IU FER] 


14.16 ”删除 表 中 记录 执行 结果 


通过 图 14.16 可 以 看 出 ,在 执行 删除 操作 前 ,遍历 表 的 结果 ， 表 中 有 两 条 记录 ， 而 在 执行 了 删除 操 
作 后 ，ID 号 为 1 的 记录 已 经 从 表 中 被 删除 了 ， 说 明 删 除 操作 顺利 执行 。 


14.4.7 ”执行 ALTER TABLE 语句 改变 表 的 结构 


(E 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 14 章 \ 执 行 ALTER TABLE 语句 改变 表 的 结构 .wmv 

数据 表 在 建立 后 并 不 是 一 成 不 变 的 ， 有 时 需要 增删 表 的 某 些 字段 。 如 通讯 录 表 在 建立 后 ， 只 有 姓 
名 、 邮 箱 、 电 话 、 地 址 几 项 可 能 还 不 能 满足 需要 ， 还 要 再 加 上 手机 号 一 项 新 的 内 容 ， 或 者 其 中 邮箱 一 
项 不 再 需要 要 予以 删除 。 这 时 就 要 使 用 到 ALTER TABLE 语句 来 改变 表 的 结构 ， 该 语句 的 使 用 格式 如 
下 所 示 : 

alter table table name add column field name1 date,add column field name2 time…; 

其 中 的 table name 是 想 要 改变 结构 的 表 名 ，field_namel 与 field name2 为 想 要 添加 的 字段 名 ， 跟 
在 它们 后 面 的 date 和 time 表示 该 字段 的 类 型 。 如 要 给 表 testl 增加 手机 和 生日 列 ， 就 可 以 使 用 这 样 的 
格式 : 

alter table test1 add column mob_phone varchar(11),add column birthday varchar(8); 

可 见 要 增加 表 的 字段 ， 后 面 要 加 上 add column 关键 字 。 

删除 字段 也 是 使 用 ALTER TABLE 语句 ， 只 不 过 跟 上 drop column 关键 字 。 有 具体 格式 如 下 所 示 : 

alter table table name drop column field name1,drop column field_name2…; 

如 要 删除 表 test 中 的 邮箱 一 项 ， 就 可 以 使 用 这 样 的 格式 : 

altertable test1 drop mail; 

通过 对 上 面 两 种 情况 的 介绍 后 ， 读 者 可 以 发 现 ， 无 论 是 为 表 添 加 字段 ， 还 是 删除 表 中 己 有 字段 ， 
均 是 使 用 ALTER TABLE 语句 。 不 同 的 是 ， 增 加 字段 后 面 跟 的 是 add column 关键 字 ， 而 删除 字段 使 用 
的 是 drop column 关键 字 。 
说 明 : 在 实际 执行 这 些 操作 之 前 首先 应 该 返回 指定 表 的 所 有 字段 , 可 以 使 用 mysql query() 函 数 发 送 SQL 

请 求 ( show columns from table name ) 来 替换 完成 。 


【实例 14-16】 以 下 代码 演示 如 何 对 表 的 结构 进行 修改 。 


e. 


$ 14€ RA MySQL 数据 库 E 


re 实例 14-16: 如 何 对 表 的 结构 进行 修改 
Si 源码 路 径 光盘 \ 源 文件 \14\14-16.php 


01 <html> 

02 <head> 

03 ”<title> 改 变 表 的 结构 </title> 

04 </head> 

05 <body> 

06 <center> 

07 <?php 

08 /使 用 mysql_connect() 函 数 对 服务 器 进行 连接 ， 如 果 出 错 ， 则 返回 相应 信息 

09 $linkzmysql connect("localhost","root","admin")or die(" 不 能 连接 到 服务 器 ".mysql_error()); 
10 mysql select db(test' $link); /选择 相应 的 数据 库 ， 这 里 选择 test 库 
11 function show field() /把 显示 字段 功能 做 成 函数 以 便 多 次 调用 
12 { 

13 $link=mysql_connect(localhost,root,"admin")or die(" 不 能 连接 到 服务 器 ".mysql_error()); 
14 mysql select db(test'Slink); /| 选择 相应 的 数据 库 ， 这 里 选择 test 库 
15 Sresult=mysql_query("show columns from test1",$link); 

16 echo "test1 表 中 现 有 的 字段 内 容 为 :"; 

17 while($rowzmysq| fetch array($result) /遍历 表 中 的 所 有 字段 

18 { 

19 echo $row["Field"]; 

20 echo "<p>"; 

21 l 

22 } 

23 echo "删除 前 : "; 

24 echo "<p>"; 

25 show field(); /显示 表 的 所 有 字段 

26 echo "<p>"; 

27 echo "删除 后 :"; 

28 echo "<p>"; 

29 $sql-"alter table test add column mob phone varchar(11),add column birthday varchar(8)"; 
30 mysql query($sql); /执行 添加 字段 的 SQL 语句 

31 $sql="alter table test1 drop mail"; 

32 mysql query($sql); /执行 删除 字段 的 SQL 语句 

33 show field(); // 再 次 显示 表 的 所 有 字段 

34 ?> 

35 </center> 

36 </body> 

37 </html> 


在 PHP 运行 环境 中 执行 该 PHP 文件 ， 执 行 结果 如 图 14.17 所 示 。 

从 图 14.17 中 可 以 看 出 ， 在 执行 改变 表 结 构 前 表 中 有 5 个 字段 ， 分 别 是 id、name、mail、phone、 
address。 可 是 在 执行 改变 表 的 结构 的 操作 后 ， 字 段 变 为 了 6 个 ， 分 别 是 id, name, phone, address, 
mob_phone、birthday。 原 来 的 mail 字段 被 删除 了 ， 而 又 新 添加 了 mob phone 和 birthday 两 个 字段 。 通 
过 执行 结果 可 以 明显 发 现 ， 改 变 表 的 结构 的 语句 是 如 何 发 生 作 用 的 。 

如 何 插入 、 浏 览 、 更 新 记录 ， 如 何 改变 表 的 结构 等 内 容 是 使 用 MySQL 数据 库 时 最 常 要 用 到 的 。 
只 有 熟练 掌握 了 这 些 基 本 内 容 ， 才 能 在 这 些 基 础 上 开发 出 基于 MySQL 数据 库 的 高 效率 的 Web 应 用 


© 


M ea 


程序 。 


一 一 | 
o ə) B p/lcabos/u D > Cj és 
删除 前 
testl 表 中 现 有 的 字段 内 容 为 :id 


name 


mail 
phone 
address 
删除 后 : 
testl 表 中 现 有 的 字段 内 容 为 id 


"m 改变 表 的 结构 执行 结果 
14.5 对 MySQL 表 的 高 级 查询 


14.4 节 介绍 的 对 数据 表 的 浏览 ， 只 是 简单 地 显示 所 有 记录 ， 并 没有 附加 任何 的 条 件 ， 也 没有 对 输 
出 结果 的 约束 。 本 节 来 介绍 常用 在 SELECT. DELETE 和 UPDATE 操作 中 所 附加 的 子 句 。 通 过 这 些 子 
句 一 方面 能 对 执行 的 操作 附加 条 件 ; 另 一 方面 也 对 显示 的 结果 有 所 限制 。 这 样 就 可 以 实现 更 多 的 功能 。 


14.5.1 使 用 WHERE FA) 


GE 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 14 章 \ 使 用 WHERE 子 句 .wmv 

不 管 是 进行 查询 、 删 除 或 者 修改 操作 时 通常 都 是 需要 附加 条 件 的 ， 而 WHERE 子 句 就 为 执行 
SELECT. DELETE 和 UPDATE 操作 的 附加 条 件 。 如 想 要 浏览 表 testl 中 ID 号 小 于 10 的 用 户 记录 就 可 
以 这 样 使 用 WHERE 子 句 : 

select * from test1 where id<10 

这 样 ， 只 有 满足 条 件 (ID 小 于 10 的 记录 ) 才 会 被 浏览 到 。 

同时 WHERE 也 可 以 用 来 作为 数据 搜索 的 条 件 。 如 果 记 录 特 别 多 ， 从 所 有 的 记录 中 找 出 一 条 记录 
就 非常 麻烦 ， 这 时 使 用 WHERE 子 句 就 简单 得 多 了 。 如 要 查看 某 一 个 人 如 张 三 ) 的 详细 信息 ， 就 可 
以 这 样 使 用 WHERE 子 句 : 


select * from test1 where name=' 张 三 ' 


这 样 就 可 以 显示 出 所 有 名 字 为 张 三 的 记录 (可 能 不 止 一 个 人 ， 因 为 可 能 有 重 名 的 情况 )。 
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同时 ，WHERE 子 句 也 可 以 用 到 UPDATE 更 新 操作 及 DELETE 删除 操作 中 。 

如 在 一 个 论坛 中 有 很 多 用 户 ， 其 中 有 普通 会 员 、 版 主 、 超 级 版 主 、 管 理 员 等 。 到 了 节日 时 ， 要 给 
所 有 的 会 员 加 分 (实际 上 是 改变 积分 的 值 》， 就 可 以 根据 用 户 不 同 的 身份 ， 给 予 不 同 的 处 理 。 

下 面 这 一 句 给 普通 用 户 增加 10 分 : 

update table name set score=score+10 where shenfen-"normal"; 

下 面 这 一 句 给 版 主 增加 100 分 : 

update table name set score=score+100 where shenfen-"banzhu"; 

下 面 这 一 句 给 超级 版 主 增加 200 分 : 

update table name set score=score+200 where shenfen-"super"; 

经 过 以 上 3 条 SQL 语句 的 操作 ， 不 同 的 用 户 就 会 被 给 予 不 同 的 积分 奖励 。 

为 什么 非 要 用 3 句 ? 用 1 名 加 上 3 个 条 件 不 是 更 好 ? 注意 这 一 点 是 不 被 允许 的 ， 因 为 MySQL 并 
不 支持 多 重 WHERE。 所 以 以 上 3 步 操作 不 能 放 到 一 条 语句 中 。 

虽然 MySQL 并 不 支持 多 重 WHERE, 但 是 可 以 使 用 AND (和 ) 、OR CR) 这 两 个 关键 字 ， 把 多 
重 条 件 组 合 起 来 使 用 。 如 要 搜索 ID 号 为 1 和 ID 号 为 10 的 用 户 的 记录 就 可 以 使 用 : 

select* from table_name where id=1 or id=10 

这 样 就 会 查询 出 所 需要 的 信息 。 同 理 ，AND 操作 是 同时 满足 两 个 条 件 的 内 容 才 会 被 查询 出 。 

WHERE 子 句 用 于 DELETE 操作 时 是 什么 情况 呢 ? 如 一 个 论坛 中 用 户 太 多 了 ， 如 果 要 删除 连续 一 
年 没有 登录 的 用 户 〈 一 般 是 没有 这 样 的 操作 的 ) 。 就 可 以 这 样 使 用 : 

delete from table name where no_login>365; 

这 样 ， 未 登录 时 间 超过 一 年 的 用 户 就 会 被 删除 。 

还 有 一 点 需要 注意 ，WHERE 子 句 的 操作 符 不 仅 有 “=”、“<”、“> ”等 这 些 数学 符号 ， 还 可 以 
使 用 “not” 表 示 罗 辑 非 。 如 要 搜索 所 有 性 别 不 为 男 的 成 员 的 信息 就 可 以 使 用 这 样 的 格式 : 

select * from table_name where sex not male 

这 样 就 可 以 选 出 所 有 性 别 不 是 男 的 记录 。 

还 有 一 个 操作 符 LIKE 可 以 用 于 模糊 查询 ， 它 的 使 用 格式 如 下 所 示 : 

select * from table_name where field_name like value 

其 中 的 field name 为 字段 〈 实 际 指 代 该 字段 的 值 ) ，value 为 某 一 个 值 。 这 样 的 使 用 是 检查 左边 的 
字段 的 值 field name 是 否 为 右边 的 value 的 子 串 。 

另外 ， 在 使 用 LIKE 操作 符 时 还 可 以 加 上 简单 的 通配符 “%”、“_”。 其 中 “%” 指 代 0 个 或 多 
个 字符 的 字符 串 ，“_” 指 代 任何 一 个 单个 字符 。 这 样 就 可 以 通过 LIKE 的 模糊 查找 功能 找 出 包含 某 个 
字 串 的 记录 。 如 下 面 的 操作 : 

select* from table name where address like "% 北 京 %" 


这 样 就 可 以 搜索 出 所 有 地 址 在 北京 的 用 户 或 者 地 址 中 包括 “北京 ”内 容 的 用 户 记 录 。 
WHERE 子 句 包含 的 内 容 相当 广泛 ， 善 于 利用 该 子 句 可 以 大 大 提高 相关 SQL 语句 的 执行 效率 。 
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14.5.2 ”使 用 LIMIT 子 句 对 结果 进行 分 页 显示 
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在 使 用 SELECT 进行 查询 时 ， 如 果 表 中 的 结果 太 多 ， 可 能 就 会 查找 出 很 多 的 结果 。 如 果 只 是 想 要 
其 中 的 几 条 该 怎么 办 ? 实际 这 种 情况 常 出 现在 分 页 操作 中 。 如 一 个 留言 短 一 共有 100 条 记录 ， 如 果 只 
想 让 一 页 出 现 10 条 记录 该 怎么 办 ? 这 时 就 要 用 到 LIMIT 子 句 。 

LIMIT iR 1 个 或 2 个 数字 参数 ， 如 果 给 定 2 个 参数 ， 第 一 个 指定 要 返回 的 第 一 行 的 偏 移 量 ， 第 二 
个 指定 返回 行 的 最 大 数目 。 注 意 初始 行 的 偏 移 量 是 0 (不 是 1) 。 它 的 使 用 格式 如 下 所 示 : 

select field_nam from table_name limit 10 


【实例 14-17 下面 使 用 一 个 实例 来 说 明 使 用 LIMIT 与 不 使 用 LIMIT 的 区 别 ( 这 里 的 表 还 使 用 testl 
表 ， 在 使 用 前 使 用 前 面 的 实例 14-9 一 实例 14-11 给 表 中 加 入 记录 。 不 过 表 的 结构 在 14.4.7 小 节 中 被 改 
变 ， 使 用 前 还 要 再 改 回 来 ) 。 


re 实例 14-17: 说 明 使 用 LIMIT 与 不 使 用 LIMIT 的 区 别 
s 源码 路 径 光盘 \ 源 文件 \14\14-17.php 


01 <html> 
02 <head> 
03 ”<title> 使 用 limit 子 旬 </title> 
04 </head> 
05 <body> 
06 <center> 
07 <?php 
08 $db_host='localhost’; IIMySQL 服务 器 名 
09 $db_user='root'; /MySQL 用 户 名 
10 $db pass-'admin'; /MySQL 用 户 对 应 密码 
11 $db name-'test'; // 要 操作 的 数据 库 
12 /使 用 mysql_connect() 函 数 对 服务 器 进行 连接 ， 如 果 出 错 ， 则 返回 相应 信息 
13 $link=mysql_connect($db_host,$db_user,$db_pass)or die(" 不 能 连接 到 服务 器 ".mysql_error()); 
14 mysql_select_db($db_name, $link); /选择 相应 的 数据 库 ， 这 里 选择 test Æ 
15 $sql="select* from test1"; /没有 加 入 LIMIT 的 SQL 语句 
16 $result=mysql_query($sql,$link); /使 用 mysql_query() 函 数 发 送 SQL 请 求 
17 echo "没有 使 用 limit 子 句 的 输出 结果 : "; 
18 echo "<p>"; 
19 echo "<table border=1>"; /使 用 表格 格式 化 数据 
20 echo "«tr»«td»ID«/td»«td» $t  «/td» «td» i48 «/td» «td» $ i& «/td» «td» 3ibtE </td></tr>"; 
21 while($row-mysql fetch array(S$result)) /遍历 SQL 语句 执行 结果 ， 把 值 赋 给 数组 
22 { 
echo "<tr>"; 
echo "«td»" $row[id']."«/td»"; /显示 ID 
echo "<td>".$rowfname]." </td>"; /显示 姓名 
echo "<td>".$row[ mail]." </td>"; /显示 邮箱 
echo "<td>".$row[phone]." </td>"; /显示 电话 


23 
24 
25 
26 
27 
e. 


28 
29 
30 
31 
32 
33 
34 
35 
36 
37 
38 
39 
40 
41 
42 
43 
44 
45 
46 
47 
48 
49 
50 
51 
52 
53 


echo "<td>".$row['address]." </td>"; 
echo "</tr>"; 
! 
echo "</table>"; 
echo "«p»"; 
echo "使 用 limit 子 句 后 的 输出 结果 : "; 
echo "«p»"; 
$sql-"select * from test1 limit 3"; 
$result-mysql query($sql,$link); 
echo "<table border=1>"; 


/ 旺 示 地 址 


/加 入 LIMIT 子 句 的 SQL 语句 
/使 用 mysql_query() 函 数 发 送 SQL 请 求 
/使 用 表格 格式 化 数据 


echo "<tr><td>ID</td><td> 姓 名 </td><td> 邮 箱 </td><td> 电 话 </td><td> 地 址 </td></tr>"; 


while($row-mysql fetch array(Sresult)) 
t 
echo "<tr>"; 
echo "«td»" Srow['id']."«/td»"; 
echo "«td»" $row[name7." </td>"; 
echo "«td»" $row[mail]." </td>"; 
echo "«td»" $row[phone"]." </td>"; 
echo "«td»" $row[ address?" </td>"; 
echo "</tr>"; 
H 
echo "</table>"; 
?> 
</center> 
</body> 
</html> 


IEA SQL 语句 执行 结果 ， 把 值 赋 给 数组 


/显示 ID 

// 显 示 姓 名 
// 显 示 邮 箱 
// 显 示 电 话 
// 显 示 地 址 


在 PHP 运行 环境 中 执行 该 PHP 文件 ， 执 行 结果 如 图 14.18 所 示 。 
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图 14.18 ”使 用 LIMIT 子 句 执行 结果 


现在 再 对 上 面 的 实例 做 小 小 的 改动 , 把 LIMIT 子 句 后 面 的 参数 3 改 为 2，3。 即 把 原来 的 1 个 参数 
变 为 2 个 参数 。 第 一 个 参数 2 为 偏 移 量 ， 第 二 个 参数 3 为 显示 的 结果 。 然 后 再 来 执行 实例 14-17， 执 行 
结果 如 图 14.19 所 示 。 
比较 两 次 的 执行 结果 可 以 明显 看 出 LIMIT 子 句 的 显示 区 别 。 不 使 用 该 子 句 将 显示 所 有 记录 ， 而 使 
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用 该 子 句 后 将 显示 指定 条 数 的 记录 。 加 入 一 个 参数 只 显示 指定 条 数 记 录 ， 加 入 两 个 参数 把 搜索 结果 按 
第 一 个 参数 进行 偏 移 再 显示 指定 条 数 的 记录 。 
f 3 laa 
Tem 
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图 14.19 使 用 LIMIT 子 句 加 两 个 参数 的 执行 结果 
14.5.8 ”使 用 ORDER BY 对 查询 结果 进行 排序 
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使 用 SELECT 语句 对 数据 表 进 行 浏览 查询 ， 所 查 出 的 记录 都 是 按照 记录 插入 的 先后 顺序 排列 的 ， 
有 时 这 样 的 结果 并 不 是 用 户 所 希望 的 ， 如 果 希 望 结果 按照 某 一 字段 的 某 一 顺序 进行 排列 ， 这 时 就 需要 
用 到 ORDER BY 子 句 。 该 子 句 的 使 用 格式 如 下 所 示 : 


select field name from table name order by field name desc 


其 中 的 field name 为 字段 ，table_name 为 表 名 ， 参 数 desc 为 降序 即 从 大 到 小 的 顺序 排列 ， 如 果 要 
使 用 升序 即 从 小 到 大 的 顺序 排列 就 要 使 用 参数 sc。 如果 不 使 用 参数 ， 默 认为 按照 升序 进行 排序 。 如 对 
3K testl 中 的 记录 按 电话 号 码 一 项 按 降序 排列 就 可 以 这 样 使 用 : 

select * from test1 order by phone desc; 


【实例 14-18】 以 下 代码 演示 如 何 使 用 ORDER BY 子 句 对 查询 结果 进行 排序 。 
K E. 实例 14-18: 如 何 使 用 ORDER BY 子 句 对 查询 结果 进行 排序 
源码 路 径 : 光盘 \ 源 文件 \14\14-18.php 


02 <head> 

03 ”<title> 使 用 order by 子 句 </title> 

04 </head> 

05 <body> 

06 <center> 

07 <?php 

08 $db host-'localhost'; IIMySQL 服务 器 名 

09 $db user-'root"; IIMySQL 用 户 名 

10 $db pass-'admin'; /MySQL 用 户 对 应 密码 


#148 使 用 MySQL 数据 库 


$db_name="test"; // 要 操作 的 数据 库 

// 使 用 mysql_connect() 函 数 对 服务 器 进行 连接 ， 如 果 出 错 ， 则 返回 相应 信息 

S$linkzmysql connect($db host$db user,$db pass)or die(" 不 能 连接 到 服务 器 ".mysql_error()); 
mysql_select_db($db_name,$link); /选择 相应 的 数据 库 ， 这 里 选择 test Æ 
$sql="select * from test1"; /没有 加 入 ORDER BY 子 句 的 SQL 语句 
$result=mysql_query($sql,$link); /使 用 mysql_query() 函 数 发 送 SQL 请 求 
echo "没有 使 用 order by 子 句 的 输出 结果 : "; 

echo "<p>"; 

echo "<table border=1>"; /使 用 表格 格式 化 数据 

echo "<tr><td>ID</td><td> 姓 名 </td><td> 邮 箱 </td><td> 电 话 </td><td> 地 址 </td></tr>"; 
while($row=mysql_fetch_array($result)) /遍历 SQL 语句 执行 结果 ， 把 值 赋 给 数组 
{ 


echo "<tr>"; 
echo "<td>".$row['id]."</td>"; // 显 示 ID 
echo "<td>".$row[name]." </td>"; /显示 姓名 
echo "<td>".$row[' mail]." </td>"; // 显 示 邮 箱 
echo "<td>".$row|'phone')." </td>"; /显示 电话 
echo "<td>".$row['address]." </td>"; / 旺 示 地 址 
echo "</tr>"; 

i 

echo "</table>"; 

echo "<p>"; 

echo "使 用 order by 子 句 后 的 输出 结果 : "S 

echo "<p>"; 


$sql="select* from test1 order by phone"; /加 入 ORDER BY 子 句 的 SQL 语句 
$result=mysql_query($sql,$link); /使 用 mysql_query() 函 数 发 送 SQL 请 求 
echo "<table border=1>"; /使 用 表格 格式 化 数据 

echo "<tr><td>ID</td><td> 姓 名 </td><td> 邮 箱 </td><td> 电 话 </td><td> 地 址 </td></tr>"; 
while($row=mysql_fetch_array($result)) /遍历 SQL 语句 执行 结果 ， 把 值 赋 给 数组 
{ 


echo "<tr>"; 
echo "«td»" $row[id']."«/td»"; /显示 ID 
echo "<td>".$row[name]." </td>"; /显示 姓名 
echo "«td»" $row[' mail]." </td>"; // 显 示 邮 箱 
echo "«td»" $row[phone']." </td>"; // 显 示 电 话 
echo "<td>".$row|'address')." </td>"; // 显 示 地 址 
echo "</tr>"; 
} 
echo "</table>"; 
?> 
</center> 
</body> 
</html> 


在 PHP 运行 环境 中 执行 该 PHP 文件 ， 执 行 结果 如 图 14.20 所 示 。 

从 执行 结果 可 以 看 出 ， 下 部 的 输出 结果 是 按照 所 有 记录 的 电话 升序 进行 排序 。 
现在 把 以 上 实例 中 的 ORDER BY 子 句 后 面 加 上 参数 desc。 再 次 执行 ， 结 果 如 图 14.21 所 示 。 
从 运行 结果 可 以 得 知 ， 下 部 的 输出 按 所 有 记录 的 电话 进行 降序 排列 。 

从 以 上 两 次 执行 结果 中 可 以 清晰 地 看 出 使 用 ORDER BY 子 句 与 不 使 用 该 子 句 的 区 别 。 
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图 14.20 使 用 ORDER BY 子 句 执行 结果 图 14.21 加 上 DESC 参数 后 的 执行 结果 


另外 在 使 用 ORDER BY 子 句 时 有 一 项 需要 注意 ，ORDER DY 子 句 允许 多 次 使 用 。 这 样 就 可 以 实 
现 多 重 排序 ， 如 下 所 示 : 

select field nam from table name order by field name,order by field name2 

如 何 理解 呢 ? 就 是 说 ， 先 对 查询 结果 按照 field name 字段 按 升 序 进行 排列 ， 如 果 有 多 个 记录 的 
field name 字段 都 相同 ， 这 时 再 按照 field name2 字段 按 升 序 进行 排列 。 这 就 是 多 重 排序 。 例 如 ， 对 某 
个 班级 的 学 生成 绩 先 按照 总 成 绩 进 行 排 序 ， 以 排出 名 次 。 如 果 两 个 学 生 的 总 成 绩 都 相同 ， 再 按照 语文 
的 成 绩 进行 排序 。 

当然 也 可 以 使 用 3 种 甚至 多 种 排序 ， 即 ORDER BY 子 句 可 以 多 次 使 用 。 

利用 本 节 介绍 的 几 种 高 级 查询 子 句 不 仅 可 以 提高 SQL 语句 执行 效率 ,还 可 以 结合 不 同 的 功能 扩展 
SQL 语句 的 功能 。 


14.6 MYySQL 数据 库 使 用 实例 


本 节 将 使 用 前 面 所 学 习 的 知识 来 完成 一 个 数据 使 用 的 综合 实例 。 主 要 内 容 包括 明确 设计 目的 、 连 
接 MySQL 服务 器 和 显示 学 生 数据 页 、 添 加 记录 页 、 修 改 记录 页 、 查 找 记 录 页 的 创建 。 


14.6.1 ”明确 设计 目的 一 一 学 生 档案 管理 系统 
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本 小 节 结 合 本 章 所 学 MySQL 数据 库 的 内 容 ， 来 做 一 个 学 生 档案 管理 系统 。 

一 个 班级 学 生 档案 管理 系统 必 备 的 功能 就 是 对 学 生 信 息 的 管理 ， 包 括 添加 、 浏 览 、 修 改 、 删 除 信 
息 等 操作 。 

这 里 先 建立 一 个 表 student 以 存放 学 生 的 信息 。 该 表 中 有 以 下 字段 : ID (记录 号 )、NAME (姓名 ) 、 
SEX (性 别 ) ~ BIRTHDAY (出 生日 期 ) S ID (学 号 ) 、PARENT (家 长 姓名 ) ~ PHONE (家 庭 电 


(m, 
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i) 、ADDRESS〔 家 庭 地 址 ) 等 。 
【实例 14-19】 以 下 代码 把 一 些 变 量 存 为 一 个 配置 文件 中 ， 以 便 多 次 调用 。 


ND 实例 14-.19: 创建 配置 文 作 000000000 
源码 路 径 光盘 \ 源 文件 \14\14-19.php 


01 <?php 

02 $host_name="localhost"; /主机 名 

03 $db user-"root"; /用 户 名 

04 $db pass-"admin"; /用 户 密码 

05 $db name-"test"; /| 数据库 名 

06 $table name-"student"; /数据 表 名 

07 $list num-10; // 每 页 显示 记录 数 
08 ?> 


该 文件 存放 了 连接 数据 库 时 必需 的 各 项 内 容 ， 这 样 需要 时 只 需 使 用 include() 或 者 require 调用 该 文 
件 即 可 ， 避 免 了 多 次 定义 。 


14.6.2 ”连接 MySQL 服务 器 建立 学 生 档案 表 
EE 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 14 章 \ 连 接 MySQL 服务 器 建立 学 生 档案 表 .wmv 


本 小 节 来 介绍 连接 到 服务 器 创建 学 生 档 案 表 : student。 
【实例 14-20】 以 下 代码 在 数据 库 中 创建 学 生 档案 表 。 


01 <?php 

02 require "14-19.php"; // 调 用 配置 文件 

03 // 连 接 MySQL 服务 器 

04 $link=mysql_connect($host_name,$db_user,$db_pass)or die(" 不 能 连接 到 服务 器 ".mysql_error()); 
05 mysql select db($db name,Slink); /| 选择 test 数据 库 

06 // 下 面 的 $sql 就 为 创建 表 的 SQL 语句 

07 $sql="create table $table name( 

08 id int(5) not null auto increment primary key, 

09 name varchar(12) not null, 

10 sex varchar(4) not null, 

11 birthday varchar(16) not null, 

12 s_id varchar(10) not null, 

13 parent varchar(12) not null, 

14 phone varchar(14) not null, 

15 address varchar(30) not null 

16 E 

17 if(mysql query($sql, $link)) /发 送 SQL 语句 执行 创建 表 的 操作 
18 echo " 表 ".$table_name." 创 建成 功 "; // 如 果 创建 成 功 显示 信息 
19 else 

20 echo "创建 数据 库 出 错 ! "; 
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在 PHP 运行 环境 中 执行 该 PHP 文件 ， 将 会 出 现 如 图 14.22 所 示 的 执行 结果 。 


图 14.22 ”建立 学 生 档 案 表 执行 结果 


创建 表 是 建立 系统 的 基础 ， 其 他 一 切 操作 都 要 在 表 中 进行 。 表 创建 完成 后 ， 下 一 步 就 是 为 表 中 添 
加 相应 的 数据 了 。14.6.3 小 节 将 介绍 显示 数据 页 面 及 添加 数据 页 面 的 创建 过 程 。 


14.6.3 ”显示 学 生 数据 页 的 创建 


EÈ 知识 点 讲解 :光盘 \ 视 频 讲 解 \ 第 14 章 \ 显 示 学 生 数据 页 的 创建 .wmv 

本 小 节 为 读者 介绍 如 何 显示 表 中 的 数据 。 显 示 数 据 当然 还 是 要 使 用 SELECT 查询 ， 但 本 小 节 的 
SELECT 查询 不 同 于 前 面 介绍 的 内 容 。 本 小 节 所 使 用 的 SELECT 查询 包括 更 多 的 内 容 ， 最 重要 的 一 项 
就 是 使 用 LIMIT 子 句 以 实现 分 页 功能 。 

【实例 14-21】 显 示 学 生 数 据 页 的 创建 。 


TE 实例 14-21， 显 示 学 生 数 据 页 的 创建 
源码 路 径 ， 光盘 '\ 源 文件 \14\14-21.php 


01 <?php 

02 error_reporting(0); 

03 require "14-19.php"; // 调 用 配置 文件 

04 if(l$_GET[page]) 

05 $page=1; 

06 else 

07 S$page-$ GET[page]; 

08 // 连 接 MySQL 服务 器 

09 $link=mysql_connect($host_name,$db_user,$db_pass)or die(" 不 能 连接 到 服务 器 ".mysql_error()); 
10 mysql_select_db($db_name, $link); /| 选择 test 数据 库 
11 // 下 面 的 $sql 就 为 创建 表 的 SQL 语句 

12 $sql-"select id from Stable name"; /查询 所 有 记录 

13 $result=mysql_query($sql,$link); /发 送 SQL 请 求 
14 $num=mysql_num_rows($result); /获得 记录 数 

15 ?> 

16 «html» 

17 «head» 

18 ”<title> 学 生 档 案 管理 系统 一 一 记录 显示 页 </title> 

19 </head> 

20 <body> 

21 <center> 

22 ”<h1> 学 生 档案 管理 系统 一 一 记录 显示 页 </h1> 

23 <p> 

24 <a href=14-22.php> 添 加 记录 </a>&nbsp; &nbsp;<a href=14-24.php> 查 找 记录 </a> 
25 <p> 

26 


<?php 
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echo "目前 共有 ".$num." 条 记录 &nbsp;&nbsp;"; // 输 出 记录 数 
$p_count=ceil($num/$list_num); /总 页 数 为 总 条 数 除 以 每 页 显示 数 
echo " 共 分 ".$p_count." 页 显示 &nbsp;&nbsp;"; // 输 出 页 数 
echo "当前 显示 第 ".$page." 页 "; 
echo "<p>"; 
if($num>0) // 如 果 记 录 数 大 于 0， 则 输出 记录 内 容 
{ 
?> 
<p> 
<table border="1"> 
<tr> 
<td>ID</td> 
<td> 姓 名 </td> 
<td> 性 别 </td> 
<td> 出 生日 期 </td> 
<td> 学 号 </td> 
<td> 家 长 姓名 </td> 
<td> 家 庭 电 话 </td> 
<td> 家 庭 住 址 </td> 
<td>&nbsp;</td> 
«tr» 
«?php 
$temp-(Spage-1)*$list num; 
$sql-"select * from $table name limit $temp,$list num"; 
$result-mysql query($sql); /| 执行 SQL 语句 
while($row=mysql_fetch_array($result)) // 通 过 循环 遍历 记录 集 
{ 
echo "<tr>\n"; 
echo "«td»".$row[id']."«/td»|n"; 
echo "«td»".$row[name7."«/td»n"; 
echo "<td>".$row['sex]."</td>\n"; 
echo "«td»".$row[birthday']."«/td»n"; 
echo "<td>".$rowf's id']."«/td»n"; 
echo "«td»" $row[parent"]."«/td» n"; 
echo "«td»".$row[phone']."«/td»n"; 
echo "«td»".$row['address7."«/td»ln"; 
echo "<td><a href=14-23.php?id=".$Srow[id1]."> 修 改 </a></td>\n"; 
echo "</tr>\n"; 
) 
echo "</table>"; 
// 以 下 为 显示 分 页 的 连接 的 内 容 
$prev page-$page-1; /定义 上 一 页 为 该 页 减 1 
$next_page=$page+1; // 定 义 下 一 页 为 该 页 加 1 
echo "<p align=\"center\"> "; 
if ($page<=1) // 如 果 当前 页 小 于 等 于 1， 则 只 有 显示 
echo "第 一 页 | "; 
else // 如 果 当 前 页 大 于 1， 则 显示 指向 第 一 页 的 链接 
echo "<a href='$PATH_INFO?page=1'> 第 一 页 </a> | "; 
if ($prev_page<1) /| 如 果 上 一 页 小 于 1， 则 只 显示 文字 
echo "上 一 页 |"; 
else // 如 果 大 于 1， 则 显示 指向 上 一 页 的 链接 
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78 echo "<a href-'$PATH INFO?page-$prev page'».E— Z1«/a» |" 

79 if ($next page»$p count) // 如 果 下 一 页 大 于 总 页 数 ， 则 只 显示 文字 

80 echo "下 一 页 |"; 

81 else // 如 果 小 于 总 页 数 ， 则 显示 指向 下 一 页 的 链接 
82 echo "<a href='$PATH_INFO?page=$next_page'> 下 一 页 </a> |" 

83 if ($page>=$p_count) /如果 当 前 页 大 于 或 者 等 于 总 页 数 ， 只 显示 文字 
84 echo "最 后 一 页 </p>\n"; 

85 else // 如 果 当 前 页 小 于 总 页 数 ， 显 示 最 后 页 的 链接 
86 echo "<a href='$PATH_INFO?page=$p_count'> 最 后 一 页 </a></p>\n"; 

87 } 

88 else 1/ 如果 没 有 记录 时 输出 信息 

89 echo "暂时 还 没有 记录 !"; 

90 ?> 

91 </body> 

92 </html> 


可 以 看 出 ， 该 实例 中 的 SELECT 与 前 几 节 介绍 的 略 有 不 同 ， 不 同 之 处 就 在 于 它 使 用 了 LIMIT 的 两 
个 参数 。 第 一 个 参数 为 返回 查询 的 偏 移 量 ， 第 二 个 参数 为 显示 的 记录 数 。 记 录 数 很 简单 ， 直 接 限 制 为 
每 页 最 多 显示 数 就 可 以 了 。 而 偏 移 量 怎么 计算 呢 ? 如 当前 页 为 第 一 页 ， 偏 移 量 为 0 就 可 以 了 ; 当前 页 
为 第 二 页 ， 偏 移 量 就 为 10; 当前 页 为 第 三 页 ， 偏 移 量 就 为 20…… 以 此 类 推 。 如 果 当 前 页 为 N， 偏 移 量 
就 为 (N-1)*$list_num， 即 前 面 页 面 显示 的 所 有 记录 数 ， 这 样 就 实现 了 分 页 的 显示 。 


14.6.4 ”添加 记录 页 的 创建 
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本 小 节 就 开始 着 手 来 为 表 中 添加 记录 。 这 里 还 是 采用 前 台 输入 加 后 台 处 理 的 方式 来 进行 。 不 过 本 
小 节 把 前 台 的 表单 输入 和 后 台 的 数据 处 理 整合 到 一 个 文件 中 ， 以 使 程序 更 加 简洁 。 

【实例 14-22】 以 下 为 添加 记录 页 代码 。 


re 实例 14-22: 添加 记录 页 
B 源码 路 径 : 光盘 \ 源 文件 \14\14-22.php 


<?php 
error_reporting(0); 
if$ POST[name7) // 如 果 没有 记录 输入 
?> 
«html» 
«head» 
<title> 学 生 档案 管理 系统 一 一 记录 添加 页 </title> 
</head> 
<body> 
«script language="javascript"> 
function Juge(theForm) 


if (theForm.name.value == "" 


alert(" 请 输入 姓名 ! "y; 
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theForm.name.focus(); 
return (false); 


H 


if (theForm.s id.value == "" 


alert(" 请 输入 学 号 ! "y; 
theForm.s id.focus(); 
return (false); 


H 
</script> 
<center> 
<h1> 学 生 档案 管理 系统 一 一 记录 添加 页 </h1> 
<a href="14-21.php"> 返 回首 页 </a> 
<table border=1> 
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«form action="<?php echo $PATH INFO ?>" method="post" onsubmit="return Juge(this)"» 


<tr> 

<td> 输 入 姓名 : </td> 

<td><input name="name" type="text"></td> 
«tr» 

<tr> 

<td> 输 入 性 别 : </td> 

<td> 


<input type=radio name=sex value= 男 checked> 男 


<input type=radio name=sex value= 女 > 女 
</td> 
</tr> 
<tr> 
<td> 出 生日 期 : </td> 
<td> 
<select name=b_y> 
<?php 
for($i=1980;$i<2004;$i++) 
echo "<option value=".$i.">".$i."\n"; 
?» 
</select> 年 
<select name=b_m> 
<?php 
for($i=1;$i<13;$i++) 
echo "<option valuez" $i."»" $i."n"; 
?> 
</select> 月 
«select name-b d» 
«?php 
for($i=1;$i<32;$i++) 
echo "<option value=".$i.">".$i."\n"; 
?> 
</select> H 
«ftd» 
«tr» 


«tr» 


// 循 环 输出 出 生年 


// 循 环 输出 出 生 月 


// 循 环 输出 出 生日 
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68 <td> 输 入 学 号 : </td> 

69 <td><input name="s_id" type="text"></td> 

70 «ftr 

71 «tr 

72 <td> 监 护 人 姓名 : </td> 

T3 <td><input name="parent" type="text"></td> 

74 «hr» 

75 <tr> 

76 <td> 家 庭 电 话 : </td> 

77 <td><input name="phone" type="text"></td> 

78 «ftr» 

79 <tr> 

80 <td> 家 庭 住址 ，</td> 

81 <td><input name-"address" type="text"></td> 

82 «ltr» 

83 <tr> 

84 «td colspan-"2"»«center»«input type=submit value=" 确 认 提交 "> 
85 «input type=reset value=" 重 新 选择 "></center></td> 

86 </tr> 

87 </form> 

88 </table> 

89 <?php 

90 ) 

91 else 

92 " 

93 /以 下 内 容 为 获取 表单 传递 的 变量 

94 $name-$ POST[name]; 

95 $sex-$ POST[sexT; 

96 Sbirthday-$ POST[b y]."".$ POST[b m]."B".$ POST[b d."B"; 
97 $s id-$ POST[s id]; 

98 $parent-$ POST[parent'; 

99 $phone-$ POST[phoneT; 

100 $address-$ POST[address?; 

101 require "14-19.php"; 

102 $link-mysql connect($host name,$db user,$db pass)or die(" 不 能 连接 到 服务 器 ", | emor()); 
103 mysql select db($db name,Slink); /选择 test 数据 库 
104 $sql-"insert into $table name (name,sex,birthday,s id,parent,phone,address) values('$name', 
'$sex','Sbirthday','$s id'/Sparent','Sphone','Saddress")"; 

105 mysql query($sql,Slink); /执行 插入 记录 的 SQL 语句 
106 ?> 

107 <html> 

108 <head> 

109 <title> 学 生 档 案 管理 系统 一 一 记录 添加 页 </title> 

110 </head> 

111 <meta http-equiv="refresh" content="2; url=14-21.php"> 

112 <body> 

113 已 经 成 功 添加 记录 ， 两 秒 后 返回 。 

114 </body> 

115 </html> 

116 <?php 

117 } 


@ 
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118 ?> 


可 以 看 出 ， 该 文件 与 前 面 对 表 进 行 操作 时 的 实例 有 所 不 同 。 不 同 之 处 在 于 前 面 实例 中 输入 数据 的 
前 台 与 处 理 数 据 的 后 台 是 分 开 的 ， 是 不 同 的 两 个 文件 ， 现 在 把 前 台 与 后 台 的 功能 整合 到 一 个 文件 中 了 。 
其 中 的 关键 就 是 表单 的 action 属性 要 指向 自身 ， 这 里 使 用 了 PHP 的 系统 变量 SPATH_INFO 指 代 文件 自 
身 ， 同 时 还 用 POST 变量 来 判断 前 后 台 操作 。 如 果 没 有 使 用 POST 变量 ， 则 判定 为 向 前 台 添加 数据 操 
fr; 如 果 有 了 POST 变量 ， 则 判定 为 后 台 处 理 添 加 数据 的 操作 。 


14.6.5 “修改 记录 页 的 创建 
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实例 14-21 中 有 一 个 指向 14-23.php 的 链接 ， 该 文件 的 作用 就 是 对 原 有 的 数据 进行 修改 。 本 小 节 就 
来 创建 这 个 修改 原 有 记录 的 文件 。 同 14.6.4 小 节 一 样 ， 这 个 文件 仍然 把 前 台 输 入 修改 内 容 与 后 台 处 理 
修改 结果 整合 为 一 个 文件 。 

【实例 14-23】 以 下 为 修改 记录 页 代码 。 


re 实例 14-23: 修改 记录 页 
.| 源码 路 径 。， 光 盘 \ 源 文件 4\14-23.php 


01 <?php 

02 error_reporting(0); 

03 if(!$_POST[name') // 和 如果 没有 记录 输入 
04 { 

05 ?» 

06 «html» 

07 «head» 

O8 ”<title> 学 生 档 案 管理 系统 一 一 记录 修改 页 </title> 
09 </head> 

10 <body> 

11 <scriptlanguage="javascript"> 

12 function Juge(theForm) 

13 

14 if (theForm.name.value == "") 
15 { 

16 alert(" 请 输入 姓名 ! "y; 
17 theForm.name.focus(); 
18 return (false); 

19 ) 

20 if (theForm.s id.value == "" 
21 { 

22 alert(" 请 输入 学 号 ! "y; 
23 theForm.s id.focus(); 
24 return (false); 

25 ) 

26 ) 

27 «script» 


28 «center» 
29 ”<h1> 学 生 档案 管理 系统 一 一 记录 修改 页 </h1> 
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<a href="14-21.php"> 返 回首 页 </a> 
<table border=1> 
«form action="<?php echo $PATH INFO ?>" method="post" onsubmit="return Juge(this)"» 
«?php 
ifS GET[id']) 
{ 
echo "没有 选择 ID 值 "; 
exit(); 
| 
else 


$id=$_GETŢ'id']; 
} 
require "14-19.php"; 
$link-mysg! connect($host name,$db user,$db pass)or die(" 不 能 连接 到 服务 器 ".mysql_error()); 


mysql_select_db($db_name,$link); /| 选择 test 数据 库 
$sql="select * from $table name where id-'Sid""; /创建 SQL 语句 
$result-mysgl guery($sgl,$link); /| 执行 SQL 查询 
$rowzmysql fetch array(Sresult); IZRAŽA 
S$temp-$row[birthday']; /把 出 生日 期 赋值 给 变量 
/以 下 代码 为 通过 不 同情 况 分 离 出 出 生 的 年 月 日 
$b_y=substr($temp,0,4); 1/ 从 出 生日 期 中 提取 年 
if(strrpos($temp," 月 ")=="7") // 查 找 月 的 位 置 以 判断 月 份 的 位 数 
{ 
$b_m=substr($temp,6,1); 1/ 从 出 生日 期 中 提取 出 月 
if(strrpos(Stemp," 日 ")=="10") /查找 日 的 位 置 以 判断 日 期 的 位 数 
$b_d=substr($temp,9,1); 1// 从 出 生日 期 中 提取 出 日 
) 
else 
$b d-substr($temp,9,2); // 从 出 生日 期 中 提取 出 日 
} 
else 
{ 


$b_m=substr($temp,6,2); 
if(strrpos($temp," A")=="11") 
{ 
$b d-substr($temp,10,1); 
) 
else 
$b d-substr($temp,10,2); 
H 
?> 
<tr> 
<td> 输 入 姓名 : </td> 
<td><input name="name" type="text" value="<?php echo $row[name']?»"»«/td» 
<hr> 
«tr» 
<td> 输 入 性 别 : </td> 
<td> 
<input type=radio name=sex value= <?php if ($row['sex']==" 男 ") echo "checked"?>> 男 
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«input type=radio name=sex value= 女 <?php if ($row[sex'] 

<hd> 

</tr> 

<tr> 

<td> 出 生日 期 : </td> 

<td> 

«select name-b y» 

«?php 
for($i=1980;$i<2004;$i++) /| 循环 输出 出 生年 
{ 


" 女 ") echo "checked"?>> 女 


echo "<option valuez" $i; 
if(Sb y--$i) echo " selected-1"; 
echo "2" $i."n"; 
) 
?> 
</select> 年 
«select name=b_m> 
<?php 
for($i=1;$i<14;$i++) /循环 输出 出 生 月 
{ 
echo "<option value=".$i; 
if($b_m==$i) echo " selected=1"; 
echo ">".$i."\n"; 
} 
?> 
</select> 月 
«select name-b d» 
«?php 
for($i=1;$i<32;$i++) // 循 环 输出 出 生日 
{ 
echo "«option valuez" Si; 
if($b d--$i) echo " selected-1"; 
echo "2". $i.n"; 
} 
?> 
</select> B 
</td> 
</tr> 
<tr> 
<td> 输 入 学 号 : </td> 
<td><input name="s_id" type="text" value="<?php echo $row[s id']?»"»«/td» 
</tr> 
<tr> 
<td> 监 护 人 姓名 : </td> 
<td><input name="parent" type="text" value="<?php echo $row[parent']?»"»«/td» 
</tr> 
<tr> 
<td> 家 庭 电话 : </td> 
<td><input name-"phone" type="text" value="<?php echo $row[phone']?»"»«/td» 
<hr> 


«tr» 
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132 <td> 家 庭 住 址 : </td> 

133 <td><input name="address" type="text" value="<?php echo $row['address']?>"></td> 
134 </tr> 

135 <tr> 

136 «td colspan="2"><center><input type=submit value=" 确 认 提交 "> 

137 <inputtype=reset value=" 重 新 选择 "></center></td> 


138 </tr> 

139 </form> 

140 </table> 

141 <?php 

142 ) 

143 else 

144 ( 

145 /以 下 内 容 为 获取 表单 传递 的 变量 

146 $namez-$ POST[name]; 

147 $sex-$ POST[sex]; 

148 $birthday-$ POST[b y].'££".$ POST[b m]."H".$ POST[b d'."B"; 
149 $s id-$ POST[s id]; 

150 $parent-$ POST[parent]; 

151 $phone-$ POST[phoneT; 

152 Saddress-$ POST[address?; 

153 require "14-19.php"; 

154 Slinkzmysql connect($host name,$db user,$db pass)or die(" 不 能 连接 到 服务 器 ".mysql_error()); 
155 mysql select db($db name,Slink); /选择 test 数据 库 
156 $sql-"update $table name set name-'$name'sex-'$sex' birthday-'$birthday',s id-'$s id', 
parent-'$parent',phone-'$phone',address-'$address""; 

157 mysql query ($sql,Slink); /执行 更 新 记录 的 SQL 语句 
158 ?> 

159 <html> 

160 <head> 

161 <title> 学 生 档案 管理 系统 一 一 记录 添加 页 </title> 

162 </head> 

163 «meta http-equiv-"refresh" contentz"2; url214-21.php"» 

164 <body> 

165 已 经 成 功 更 改 记录 ， 两 秒 后 返回 。 

166 </body> 

167 </html> 

168 <?php 

169 

170 ?> 


该 文件 的 一 个 特征 是 把 修改 记录 的 前 台 输 入 内 容 与 后 台 处 理 数据 结合 了 起 来 ， 但 这 里 还 存在 一 个 
问题 ， 在 输入 学 生 的 出 生日 期 时 ， 把 输入 记录 格式 化 后 存 入 表 中 ， 当 需要 修改 时 ， 如 果 要 求 显示 原来 
的 出 生日 期 , 就 必须 把 原来 的 数据 还 原 。 这 里 用 了 比较 第 一 点 的 方法 按 位 数 分 别提 取出 年 月 日 来 实现 。 
其 实 如 果 在 创建 表 时 把 出 生年 、 月 、 日 分 别 创 建成 字段 就 不 会 有 这 样 的 问题 存在 了 。 


14.6.6 ”查找 记录 页 的 创建 


EH 知识 点 讲解 : 光盘 \ 视 频 讲 解 \ 第 14 章 \ 查 找 记录 页 的 创建 .wmv 
如 果 班 级 学 生 的 人 数 特别 多 ， 记 录 分 了 好 多 页 显示 。 要 从 表 中 查找 某 一 条 或 儿 条 特定 的 记录 是 


e. 
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当 困难 的 。 所 以 ， 有 必要 创建 一 个 查找 记录 的 页 面 ， 本 小 节 就 来 设计 该 页 面 。 该 页 面 首先 让 用 户 选 择 
查找 记录 所 依据 的 条 件 ; 然后 输入 该 条 件 的 内 容 , 如 用 户 先 选择 学 号 ; 再 输入 学 号 的 内 容 ,如 200602003; 
最 后 就 把 结果 交 给 后 台 来 处 理 了 。 同 前 两 小 节 一 样 ， 查 找 记 录 的 页 面 ， 依 然 采用 前 台 与 后 台 整 合 在 一 
起 的 模式 。 

【实例 14-24】 以 下 为 查找 记录 页 代码 。 


实例 14-24: 查找 记录 页 
源码 路 径 光盘 \ 源 文件 \14\14-24.php 


02 <head> 

03 ”<title> 学 生 档 案 管理 系统 一 一 记录 查找 页 </title> 
04 </head> 

05 <body> 

06 <center> 

07 ”<h1> 学 生 档案 管理 系统 一 一 记录 查找 </h1> 


08 <p> 

09 <a href=14-21.php> 返 回 </a> 

10 <p> 

11 <?php 

12 error reporting(0); 

13 if(lS POST['find v"]) // 如 果 没 有 查找 类 别 ， 则 显示 HTML. 内 容 
14 ( 

15 ?» 

16 <script language-"javascript"» 

17 function Juge(theForm) 

18 ( 

19 if (theForm.find v.value == "") 
20 i 

21 alert(" 请 输入 查询 内 容 ! y 
22 theForm.find v.focus(); 
23 return (false); 

24 ) 

25 ) 


26 </script> 

27 «table border-"1"» 

28 <form action-"«?php echo SPATH INFO ?>" method="post" onsubmit-"return Juge(this)"> 
29 <tr> 

30 ”<td> 选 择 查询 类 别 : </td> 

31 <td><selectname="find t"> 

32 <option value='name'> 姓 名 </option> 

33 «option value=s_id> 学 号 </option> 

34 «option value=birthday> 出 生日 期 </option> 
35 <option value=parent> 监 护 人 </option> 

36 «option value=phone> 电 话 </option> 

37 «option value=address> 住 址 </option> 

38 </select></td> 

39 <hr> 

40 <tr> 
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41 
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<td> 输 入 查询 内 容 : </td> 
<td><inputtype=text name-"find v"»«/td» 
«tr» 
«tr» 
«td colspan-2»«center»«input type=submit value= 确 认 提交 > 
<input type=reset value= 重 新 填写 ></center></td> 
</tr> 
</table> 
</center> 
<?php 
} 
else 
ji 
require "14-19.php"; // 调 用 配置 文件 
$link=mysql_connect($host_name,$db_user,$db_pass)or die(" 不 能 连接 到 服务 器 ".mysql_error()); 
mysql_select_db($db_name,$link); /| 选择 test 数据 库 
$strsql-"select*from $table name where ".$ POST[find t]." like ".$ POST[find v].""; 
$result=mysql_query($strsql,$link) or die(mysql error()); 
$amount-mysql num rows(Sresult); 
if($amount=="0") echo "<p> 没 有 记录 "; /如 果 没 有 找到 匹配 记录 ， 则 输出 提示 
else 
{ 
?> 
<h3> 下 面 是 查 出 来 的 结果 </h3> 
<p> 
<table border=1> 
<tr> 
<td>ID</td> 
<td> 姓 名 </td> 
<td> 性 别 </td> 
<td> 出 年 日 期 </td> 
<td> 学 号 </td> 
<td> 监 护 人 </td> 
<td> 电 话 </td> 
<td> 地 址 </td> 
</tr> 
<?php 
while($row=mysql_fetch_array($result)) 
t 
echo "<tr> 
«td»" Srow["id"]."«/td» 
«td»".$row['name"]."«/td» 
«td»" $row['sex"]."«/td» 
«td»".$row['birthday"]."«/td» 
«td2".$row['s id"]."«/td» 
«td»" $row['parent"]."«/td» 
«td2" .$row['phone"]."«/td» 
«td2" $row['address"]."«/td» 
«Itr»"; 
h 


echo "«/table»«/center?"; 


sus gams eee 0o 


92 ) 

93 } 

94 ?> 

95 </body> 
96 </html> 


该 文件 有 两 个 要 点 ， 一 个 是 使 用 了 WHERE T£): 另外 一 个 是 使 用 了 WHERE 子 句 的 LIKE 操作 
符 ， 即 带 条 件 的 模糊 查找 。 这 样 虽然 降低 了 查找 精度 ， 但 却 提高 了 查找 的 准确 性 。 


随 着 该 文件 的 创建 完毕 ， 该 学 生 档案 管理 系统 也 基本 上 成 型 了 。 下 面 就 来 实际 地 测试 一 下 该 系统 
的 使 用 情况 ， 以 排除 BUG。 


14.6.7 学生 档 案 管理 系统 实际 使 用 


GE 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 14 章 \ 学 生 档 案 管理 系统 实际 使 用 .wmvy 
由 于 表 已 经 在 14.6.2 小 节 创建 完毕 ， 所 以 直接 从 实例 14-21 开始 执行 。 由 于 表 中 并 没有 任何 记录 ， 
所 以 首次 执行 该 系统 ， 其 执行 结果 如 图 14.23 所 示 。 
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目前 共有 0 条 记录 共 分 0 页 显示 当 痢 显 示 第 ! 页 
暂时 还 没有 记录 ! 
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14.23 ”记录 显示 页 第 一 次 执行 结果 
这 时 就 算 执 行 “ 查 找 记 录 ” 也 会 一 无 所 获 。 所 以 还 是 老 老实 实地 执行 “添加 记录 ” 吧 。 单 击 “ 添 
加 记录 ”链接 后 ， 出 现 如 图 1424 所 示 的 执行 结果 。 
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图 14.24 ”执行 记录 添加 页 执行 结果 


RE, 按 要 求 填 入 适当 的 学 生 信息 。 WHEA B. 19994 5 H 20 H, 201301001, 大 比 利 、1234567、 
东区 十 三 街 28 号 。 输 入 内 容 后 ， 单 击 “ 确 认 提 交 ” 按 钮 。 由 于 系统 在 处 理 完 提交 的 记录 后 就 会 直接 转 
到 记录 显示 页 ， 所 以 提交 后 的 记录 显示 页 如 图 14.25 所 示 。 
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图 14.25 已 经 存在 记录 的 记录 显示 执行 结果 


可 以 看 出 ， 已 经 显示 出 了 所 添加 的 记录 ， 说 明 添加 记录 及 显示 记录 均 执 行 正 常 。 

这 时 就 可 以 对 记录 1 进行 修改 了 。 如 记 错 了 门牌 号 ， 把 原本 26 号 写成 了 28 号， 那么 现在 把 门牌 
号 改过 来 。 单 击 记录 后 面 的 “修改 ”链接 ， 其 结果 如 图 1426 所 示 。 
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1426 记录 修改 页 执行 结果 
从 图 14.26 可 以 看 出 , 该 页 正确 显示 出 了 原 有 的 记录 内 容 ， 并 等 待 用 户 输入 新 的 信息 。 这 里 把 家 庭 
住址 一 项 的 “东区 十 三 街 28 号 ”中 的 28 号 改 为 26 号 。 然 后 单 击 “ 确 认 提 交 ” 按 钮 ， 直 接 跳 转 到 了 记 
录 显 示 页 。 结 果 如 图 14.27 所 示 。 
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1427 ”记录 修改 后 记录 显示 页 执行 结果 
从 图 14.27 的 执行 结果 可 以 看 出 家 庭 住 址 一 项 已 经 由 原来 的 “东区 十 三 街 28 号 ” 变 成 了 “东区 十 
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三 街 26 号 ”， 说 明 修改 记录 页 也 执行 正常 。 

下 面 测试 记录 显示 页 的 分 页 功能 。 要 想 测试 此 功能 的 前 提 是 : 表 中 存放 的 记录 数 要 多 于 在 实例 14-19 
中 所 定义 的 $list_num 每 页 显示 数 。 这 里 继续 为 表 中 添加 记录 ， 以 测试 分 页 显示 的 功能 。 为 了 方便 查看 分 
页 功能 ， 暂 时 把 $list num 改 为 3。 当 表 中 记录 多 于 3 条 时 ， 实 例 14-21 的 执行 结果 将 如 图 14.28 所 示 。 
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14.28 ”记录 多 于 一 页 的 执行 结果 


从 图 1428 可 以 看 出 , 这 时 已 经 显示 出 了 指向 “下 一 页 ”链接 。 单 击 该 链接 将 显示 后 面 的 两 条 记录 ， 
如 图 14.29 所 示 。 
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E1429 打开 “最 后 一 页 ”链接 的 执行 结果 
从 图 14.28 及 图 14.29 可 以 发 现 ， 分 页 功能 已 经 得 到 实现 。 


下 面 继续 来 测试 查找 记录 的 功能 。 在 主页 面 上 单 击 “ 查 找 记 录 ” 链 接 ， 将 会 转 到 查找 记录 页 ， 执 
行 结果 如 图 14.30 所 示 。 
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这 里 ， 选 择 “ 姓 名 ”作为 选择 条 件 ， 在 查询 内 容 一 栏 中 输入 TOM， 然 后 单 击 “确认 提交 ”按钮 ， 
将 出 现 如 图 14.31 所 示 的 执行 结果 。 
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结果 显示 出 了 姓名 为 TOM 的 学 生 的 记录 , 说 明 记录 查找 功能 正常 运行 。 至此， 该 系统 基本 上 已 经 
测试 完毕 。 

不 过 系统 还 有 个 模块 ， 如 学 生 转 学 ， 就 不 用 继续 保留 其 记录 。 就 要 将 相应 的 记录 从 库 表 中 删除 ， 
即 记 录 的 删除 模块 。 结 合 前 面 所 介绍 的 内 容 ， 这 个 功能 也 是 很 容易 实现 的 。 有 兴趣 的 读者 不 妨 自 己 动 
手 把 删 除 记录 这 个 功能 添加 上 ， 这 样 整个 系统 就 更 加 完善 了 。 

本 节 通 过 一 个 简单 的 实例 ， 使 读者 把 常用 的 数据 库 表 操 作 组 织 起 来 。 可 以 说 是 对 学 过 知识 的 一 次 
检阅 。 其 实说 到 底 ， 数 据 库 操作 最 常用 的 也 就 是 浏览 、 添 加 、 修 改 、 删 除 这 几 项 。 至 于 用 何 种 方式 ， 
如 何 去 实现 这 些 功能 ， 就 需要 在 实践 中 不 断 摸 索 了 。 


14.7 本 章 小 结 


数据 库 应 用 是 动态 网 页 技术 最 重要 的 应 用 之 一 。 动 态 网 页 技术 只 有 充分 与 数据 库 结 合 ， 才 能 发 挥 
动态 网 页 技术 的 真正 魅力 。PHP 与 MySQL 更 是 一 对 黄金 组 合 ， 所 以 学 习 PHP 自然 就 要 学 习 MySQL 
数据 库 。 

本 章 为 读者 介绍 了 MySQL 数据 库 的 知识 。 先 从 关系 型 数据 库 入 手 ， 介 绍 了 什么 是 关系 型 数据 库 
及 关系 型 数据 库 所 能 实现 的 功能 。 然 后 ， 又 为 读者 介绍 了 PHP 中 常用 的 MySQL 函数 。 熟 练 掌 握 这 些 
函数 对 编写 基于 数据 库 的 Web 程序 将 起 到 事半功倍 的 效果 。 

这 之 后 为 读者 介绍 了 MySQL 数据 库 的 相关 操作 ， 包 括 如 何 连 接 到 MySQL 服务 器 、 显 示 可 用 数据 
库 、 创 建新 的 数据 库 、 在 库 中 建 表 及 删除 数据 库 等 内 容 。 数 据 操 作 的 核心 是 对 表 的 操作 ， 所 以 接 下 来 
就 为 读者 详细 介绍 了 如 何 对 表 执 行 INSERT INTO 插入 、SELECT 查询 、UPDATE 更 新 、DELETE 删除 
操作 以 及 ALERT 修改 表 结 构 操作 等 关键 内 容 。 

其 后 又 介绍 了 高 级 查询 的 使 用 ， 包 括 WHERE. LIMIT, ORDER BY 子 句 的 用 法 。 最 后 ， 通 过 一 
个 实际 的 例子 ， 把 本 章 所 学 的 内 容 综合 起 来 ， 对 所 学 的 内 容 做 了 一 个 很 好 的 实际 应 用 及 总 结 。 

通过 本 章 的 学 习 , 相信 读者 对 于 如 何 使 用 MySQL 与 PHP 结合 创建 Web 应 用 程序 都 会 有 一 个 深刻 
的 认识 。 
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习题 14-1 开启 MySQL 服务 并 且 使 用 mysql_connect() 函 数 连接 服务 器 并 在 连接 出 错时 终止 程序 
运行 ， 输 出 错误 信息 。 
【分 析 】 该 习题 主要 考查 读者 对 PHP 连接 MySQL 方法 的 掌握 。 
【关键 代码 】 
$link=mysql_connect(localhost,root,admin')or die(mysql_error()); 


习题 14-2 在 习题 14-1 连接 数据 库 的 基础 上 使 用 mysql_list_dbs() 函 数列 出 数据 库 中 存在 的 所 
有 库 。 
【分 析 】 该 习题 主要 考查 读者 对 mysql_list_dbs0 函 数 的 使 用 。 
【关键 代码 】 
$db listzmysql list dbs(Slink); 
while($db2mysql fetch object(Sdb list)) 


{ 
echo $db->Database; 


) 


习题 14-3 ”在 习题 14-1 的 基础 上 使 用 mysql_select_db() 函 数 选择 名 为 test 的 数据 库 。 
【分 析 】 该 习题 主要 考查 读者 对 选择 数据 库 函 数 mysql_select_db0 的 使 用 。 
【关键 代码 】 
mysql_select_db(test',$link); 
习题 14-4 在 习题 14-3 的 基础 上 使 用 mysq_query0 函 数 发 送 一 条 查询 当前 数据 库 中 所 有 数据 表 的 
SQL 查询 语句 。 
【分 析 】 该 习题 主要 考查 读者 对 发 送 SQL 查询 语句 及 mysql_query() 函 数 的 使 用 。 
【关键 代码 】 
S$res=mysql_query("SHOW TABLES", $link); 


习题 14-5 ”在 习题 14-4 的 基础 上 将 查询 结果 输出 。 
【分 析 】 该 习题 主要 考查 读者 对 查询 结果 进行 输出 的 掌握 。 
【关键 代码 】 
$res-mysql query("SHOW TABLES", $link); 
while($tb name-mysql fetch array($res))( 
echo $tb name[0]; 
) 


第 4 篇 应 用 篇 


本 篇 是 本 书 的 最 后 一 篇 ,主要 介绍 了 使 用 PHP 实现 人 机 交互 以 及 四 个 简 
易 程序 : 计数 器 程序 、 投 票 程序 、 留 言 板 程序 以 及 博客 程序 ,两 个 系统 : BBS 
系统 和 网 上 商城 全 站 系统 。 通 过 本 篇 的 学 习 ， 读 者 可 以 了 解 开发 实际 项 目的 
流程 以 及 掌握 开发 实际 项 目的 能 力 。 
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在 本 书 的 第 1 章 曾 就 动态 网 页 与 静态 网 页 的 区 别 为 读者 做 了 介绍 ， 其 中 动态 网 页 的 一 个 显著 特征 
就 在 于 它 能 实现 人 机 互动 。 对 用 户 输入 或 者 选择 的 内 容 能 做 出 相应 的 回应 ， 这 也 是 动态 网 页 区 别 于 静 
态 网 页 的 一 个 特征 。 其 他 动态 技术 是 这 样 ，PHP 当然 也 不 例外 。 用 PHP 也 能 实现 人 机 互动 ， 本 章 就 为 
读者 介绍 如 何 用 PHP 实现 人 机 互动 。 

人 机 互动 一 般 采 用 两 种 方式 : 一 种 采用 表单 ， 通 过 不 同 的 选项 ， 或 者 输入 不 同 的 内 容 ， 返 回 结果 
也 不 同 ; 另 一 种 是 采用 URL 地 址 加 上 各 种 参数 实现 互动 ， 参 数 不 同 ， 返 回 的 内 容 也 有 所 不 同 。 基 于 这 
两 种 方式 ， 本 章 内 容 主 要 也 分 为 两 大 部 分 : 用 表单 实现 人 机 互动 ; URL 参数 与 PHP。 通 过 本 章 的 学 习 ， 
读者 能 够 熟练 地 使 用 这 两 种 方式 实现 人 机 互动 ， 从 而 能 在 此 基础 上 写 出 丰富 的 Web 应 用 程序 。 


15.1 用 表单 实现 人 机 互动 


表单 (Form) 是 最 常用 的 网 页 组 件 ， 同 时 也 是 交互 式 网 页 ， 实 现 人 机 互动 的 最 常用 的 方式 。 不 管 
是 在 动态 的 ASP、PHP、JSP 文件 中 ， 还 是 在 静态 的 HTM、HTML 等 文件 中 都 可 以 发 现 表 单 的 身影 。 
本 节 就 来 为 读者 介绍 表单 的 使 用 以 及 如 何 使 用 表单 来 实现 人 机 互动 。 


15.1.1 表单 元 素 的 组 成 


GB 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 15 章 \ 表 单元 素 的 组 成 .wmv 

表单 由 表单 元 素 构 成 ， 常 用 的 表单 元 素 有 以 下 儿 种 : TEXT (文本 框 ) . PASSWORD (密码 输入 
框 ) 、BUTTON (普通 按钮 》 、RADIO ( 单 选 按钮 )、CHECKBOX( 复 选 杠 )、SELECT (列表 框 )、 
TEXTAREA (文本 域 ) 、SUBMIT (提交 按钮 )》 、RESET ( 重 置 按 钮 )、HIDDEN (隐藏 域 ) 等 。 下 
面 分 别 对 这 些 表单 元 素 做 简单 的 介绍 。 

1. TEXT (文本 框 ) 

文本 框 允许 用 户 输入 字符 、 数 字 或 者 中 文字 符 等 内 容 ， 它 常用 的 属性 有 name. value. size 等 。 

文本 框 的 使 用 如 下 所 示 : 

«input type="text" name-"username" value=" 在 这 里 输入 用 户 名 " size="20"> 

其 中 ，name 属性 指 该 表单 元 素 的 名 称 ， 一 是 区 别 于 其 他 表单 元 素 的 标志 ， 另 外 设置 该 属性 以 便 在 
程序 中 能 够 调用 该 表单 元 素 。 一 个 表单 元 素 有 属于 自己 的 name (或 者 ID ) 属性 , 才能 被 正常 调用 。value 
属性 指 代 文本 输入 框 的 默认 值 ， 即 在 用 户 没有 任何 输入 的 情况 下 显示 的 值 。size 属性 指 该 文本 输入 框 
在 浏览 器 中 表现 出 的 长 度 ， 值 越 大 ， 文 本 框 就 越 长 。 在 多 数 浏览 器 中 ， 文 本 框 的 size 属性 默认 是 20 
T. 
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2. PASSWORD (密码 输入 框 ) 

基本 属性 与 TEXT 相同 。 不 同 的 是 ， 文 本 框 中 可 以 输入 中 文 或 者 其 他 字符 ， 而 一 旦 PASSWORD 
获得 焦点 ， 中 文 输入 法 将 不 再 起 作用 。PASSWORD 里 面 只 能 输入 键盘 上 所 标 出 的 符号 ， 而 不 能 输入 中 
文 。 另 外 ，TEXT 中 所 输入 的 内 容 全 都 是 可 见 的 ， 而 PASSWORD 中 输入 的 所 用 信息 都 将 以 星 号 CO 
显示 。 之 所 以 这 样 就 是 为 了 保护 密码 不 被 别人 发 现 。 

3. BUTTON (普通 按钮 ) 

普通 按钮 的 使 用 如 下 所 示 : 

«input type="button" value=" 点 击 这 里 " onclick="functionname()"> 

该 表单 元 素 ， 也 具有 NAME 属性 与 VALUE 属性 ， 属 性 的 意义 与 TEXT 大 同 小 异 。 通 常情 况 下 ， 
BUTTON 元 素 还 会 有 onclick 〈 单 击 ) 事件 ， 该 事件 通常 指向 JavaScript 函数 。 这 样 ， 在 按钮 按 下 的 情 
况 下 就 能 够 执行 相应 的 操作 。 

4. RADIO ( 单 选 按钮 ) 

单 选 按 钮 的 使 用 如 下 所 示 : 

<input type="radio" name="sex" value=" 男 " checked> 

单 选 按钮 通常 是 以 一 组 出 现 ， 该 组 应 具有 相同 的 name 属性 和 不 同 的 value 属性 。 在 出 现 的 一 组 单 
选 按钮 中 ， 只 允许 用 户 选择 一 个 ， 所 以 叫 单 选 按钮 。 如 果 某 个 单 选 按钮 的 初始 状态 为 选中 状态 ， 则 该 
单 选 按钮 有 checked 属性 。 

5. CHECKBOX (Siti) 

复 选 框 的 使 用 如 下 所 示 : 

«input type="checkbox" name="fav" value=" 游 戏 "> 

该 表单 元 素 和 RADIO 类 似 ， 通 常 也 是 以 一 组 出 现 ， 该 组 具有 相同 的 name 属性 和 不 同 的 value 属 
性 。 不 过 与 RADIO 不 同 的 是 ， 在 一 组 中 允许 用 户 进行 多 项 选择 ， 所 选择 的 结果 都 将 被 发 送 到 指定 的 
URL 进行 处 理 。 

6. SELECT (列表 框 ) 

列表 框 的 使 用 如 下 所 示 : 


«select namez"type" size="1"> 
«option value="1">1</option> 
«option value-"2"»2«/option? 
«option value="3">3</option> 

</select> 


该 表单 元 素 与 前 面 提 到 的 几 种 有 一 定 的 区 别 。select 元 素 既 有 name 属性 ， 也 有 size 属性 ， 它 的 每 
个 value 属性 却 包括 在 其 下 的 每 个 <option> 项 里 面 ， 即 每 个 <option> 项 对 应 一 个 value， 不 应 有 重复 。 另 
外 ， 根 据 size 属性 的 不 同 ，select 元 素 在 浏览 器 中 会 有 不 同 的 形式 。 当 size 等 于 1 时 ， 表 现 为 下 拉 菜 单 
的 形式 ; 当 size 大 于 1 时 ， 则 表现 为 列表 框 形式 。 


7. TEXTAREA (文本 域 ) 

文本 域 的 使 用 如 下 所 示 : 

<textarea name="content" rows="5" cols="40"> 内 容 在 这 里 输入 </textarea> 

TEXTAREA 又 叫 多 行文 本 框 ， 这 是 相对 于 TEXT 而 言 的 。 因 为 TEXT 所 输入 的 内 容 只 能 是 一 行 ， 
中 间 不 允许 也 不 会 出 现 换行 。 而 TEXTAREA 则 不 然 ， 里面 可 以 随意 换行 。 表 征 该 元 素 样式 的 属性 有 
两 个 ， 分 别 是 rows( 行 ) 与 cols ( 列 ) 。rows〔 行 ) 的 大 小 决定 了 TEXTAREA 的 高 度 ， 而 cols C9) 
的 大 小 则 决定 了 TEXTAREA 的 宽度 。 另 外 ， 该 表单 元 素 也 没有 value 属性 。 如 果 要 为 文本 域 设 定 初始 
值 ， 把 想 要 设 定 的 内 容 放 在 “<textarea> ”标记 与 “</textarea> ”标记 之 间 即 可 。 

8. SUBMIT (提交 按钮 ) 

提交 按钮 的 使 用 如 下 所 示 : 

«input type="submit" value=" 提 交 "> 

提交 按钮 的 作用 是 把 表单 输入 结果 发 送 到 指定 的 URL， 当 单 击 事件 发 生 时 ， 结 果 将 会 被 提交 。 该 
表单 元 素 也 有 name 与 value 属性 。 作 用 与 上 面 介 绍 的 元 素 的 作用 相 类 似 ， 此 处 不 再 袭 述 。 

9. RESET ( 重 置 按钮 ) 

重 置 按钮 的 使 用 如 下 所 示 : 

<input type="reset" value=" 重 新 填写 "> 

重 置 按钮 的 作用 是 把 表单 中 所 有 填写 好 的 内 容 恢 复 到 原始 值 ， 当 表单 中 的 内 容 需 要 重新 填写 时 单 
击 该 按钮 。 同 时 该 元 素 也 具有 name 与 value 属性 。 

10. HIDDEN (隐藏 域 ) 

隐藏 域 的 使 用 如 下 所 示 : 

<input type="hidden" name="hide" value="hideinfo"> 

如 果 有 一 些 信息 不 方便 或 者 不 必要 显示 出 来 ， 使 用 HIDDEN 是 比较 方便 的 ， 该 元 素 并 不 在 浏览 页 
面 上 显示 。 由 于 它 不 能 显示 的 特性 ， 所 以 通常 情况 下 都 要 为 HIDDEN 指定 一 个 value 值 ， 并 且 该 值 是 
不 能 被 用 户 改变 的 。 而 name 属性 则 与 上 面 介绍 的 其 他 表单 元 素 类 似 。 
15.1.2 ”在 普通 Web 页 中 插入 表单 


YA 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 15 章 \ 在 普通 Web 页 中 插入 表单 -wmv 
在 普通 的 Web 页 中 插入 表单 的 操作 步骤 如 下 所 示 。 
(1) 在 网 页 的 适当 位 置 放置 如 下 的 代码 : 


«form name-f name action-url method=get or post» 
</form> 


其 中 的 f_name 指 该 整个 表单 域 的 名 称 ; URL 为 处 理 该 表单 结果 的 URL 地 址 ; method 则 表明 采用 
何 种 方式 发 送 表 单 域 的 数据 。 
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(20 把 所 需要 的 表单 元 素 放 入 “<form>” 标 记 与 “</form> ”标记 之 间 即 可 。 
【实例 15-1】 以 下 代码 在 一 个 普通 Web 页 中 插入 一 组 表单 。 


实例 15-1; 在 一 个 普通 Web 页 中 插入 一 组 表单 
源码 路 径 : 光盘 \ 源 文件 \15\15-1.php 


<html> 
<head> 
<title> 插 入 表单 实例 </title> 
</head> 
<body> 
<center> 
<h3> 插 入 表单 实例 </h3> 
<p> 
<table border=1> 
<form> 
<tr> 
<td> 姓 名 : </td> 
«td» «input type=text name="name" sizez"12"»«/td» 
</tr> 
<tr> 
<td> 性 别 : </td> 
<td> 
<input type=radio name=sex value=" 男 " checked> 男 
<input type=radio name=sex value=" 女 "> 女 
</td> 
«tr» 
«tr» 
<td> 生 日 : </td> 
<td> 
<select name=month> 
<option value=1>1</option> 
<option value=2>2</option> 
<option value=3>3</option> 
<option value=4>4</option> 
<option value=5>5</option> 
<option value=6>6</option> 
<option value=7>7</option> 
<option value=8>8</option> 
<option value=9>9</option> 
<option value=10>10</option> 
<option value=11>11</option> 
<option value=12>12</option> 
</select> 月 
<select name=date> 


<option value=1>1</option> 
<option value=2>2</option> 
<option value=3>3</option> 
<option value=4>4</option> 
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44 <option value=5>5</option> 

45 <option value=6>6</option> 

46 <option value=7>7</option> 

47 <option value=8>8</option> 

48 «option value-9»9«/option» 

49 «option value=10>10</option> 

50 «option value-11211«/option» 

51 «option value=12>12</option> 

52 «option valuez13»13«/option» 

53 «option value=14>14</option> 

54 <option value215»15«/option» 

55 <option value=16>16</option> 

56 «option valuez17217«/option» 

57 «option value218»18«/option» 

58 «option value=19>19</option> 

59 «option value=20>20</option> 

60 «option value=21>21</option> 

61 «option value=22>22</option> 

62 «option value=23>23</option> 

63 «option value=24>24</option> 

64 «option value=25>25</option> 

65 «option value=26>26</option> 

66 «option value=27>27</option> 

67 «option value=28>28</option> 

68 «option value=29>29</option> 

69 «option value=30>30</option> 

70 «option value=31>31</option> 

71 </select> A 

72 </td> 

73 «tr» 

74 <tr> 

75 <td> 爱 好 : </td> 

76 <td> 

77 «input type-checkbox name-favior[] value=" 旅 游 "> 旅游 
78 <inputtype=checkbox name-favior[] value=" 运 动 "> 运动 
79 <inputtype=checkbox name-favior[] value=" 看 电影 "> 看 电影 <p> 
80 <input type=checkbox name-favior[] value=" 游 戏 "> 游戏 
81 «input type=checkbox name-favior[] value=" 上 网 "> 上 网 
82 «input type=checkbox name=favior[] value=" 听 音乐 "> 听 音 乐 <p> 
83 «input type=checkbox name-favior[] value=" 登 山 "> 登山 
84 <input type=checkbox name-favior[] value=" 聊 天 "> 聊天 
85 «ftd» 

86 «itr» 

87 «tr» 

88 <td> 其 他 : </td> 

89 <td> 

90 <textarea cols=24 rows=5 name=other> 

91 其 他 信息 在 这 里 输入 : 

92 </textarea> 
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93 </td> 
94 «itr» 
<tr> 
96 <td colspan="2"> 
97 <center> 
98 <input type=submit value=" 提 交 "> 
99 «input type=reset value=" 重 置 "> 
100 </center> 
101 <hd> 
102 «ftr» 
103 </form> 
104 </table> 
105 </center> 
106 </body> 
107 </html> 


在 PHP 运行 环境 下 执行 该 PHP 文件 ， 执 行 结果 如 图 15.1 所 示 。 
Ee) 

E hepy/localhost/15-1 
插入 表单 示例 

HE. 

性 别 , |68 Ox 

(EB. [VAN vIB 

C Ceu) 口 看 电影 

| 爱好 ，| 口 游戏 口上 网 口 听 音 乐 

口 登 山 口 聊天 

其 他 信息 在 这 里 输入 


RM. 


m 


图 15.1 插入 表单 实例 执行 结果 


以 上 代码 中 使 用 了 多 种 表单 元 素 。 通 过 实例 代码 及 其 执行 结果 可 以 了 解 如 何在 普通 Web 页 中 插入 
表单 元 素 及 如 何 使 用 各 种 表单 元 素 。 


15.1.3 ”更 改 表单 的 action 属性 到 PHP 程序 


GEH 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 15 章 \ 更 改 表 单 的 action 属性 到 PHP 程序 .wmv 

只 有 表单 ， 相 当 于 只 有 前 台 ， 如 果 没 有 后 台 的 支撑 ， 只 有 表单 的 前 台 就 什么 也 做 不 了 。 连 接 前 台 
与 后 台 之 间 的 纽带 就 是 表单 的 action 属性 。 所 以 ， 要 想 让 表单 起 作用 ， 就 必须 有 特定 的 后 台 处 理 程序 ; 
而 要 想 让 后 台 处 理 程序 为 前 台 表 单 服务 ， 就 必须 为 表单 指定 action 属性 。 表 单 的 action 属性 通常 为 一 
个 URL 地 址 。 

在 实例 15-1 中 的 form 标签 没有 任何 属性 , 这 里 为 其 指定 action=15-2.php (现在 这 个 文件 并 不 存在 ， 
在 15.1.5 小 节 将 会 创建 ) 。 


KA aaa 


15.1.4 表单 method 属性 POST 5 GET 区 别 


GH 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 15 章 \ 表 单 method 属性 POST 5 GET 区 别 .wmv 

在 15.1.2 小 节 就 曾 为 读者 介绍 过 ， 表 单 的 method 属性 指 代表 单数 据 的 发 送 方式 。 通 常 表单 数据 通 
过 两 种 方式 发 送 到 目标 URL。 一 种 是 POST 方式 ， 另 一 种 是 GET 方式 。 这 两 种 方式 是 有 一 定 区 别 的 。 

理论 上 两 者 的 区 别 : 用 GET 方法 提交 的 表单 ， 提 交 的 数据 被 附加 到 URL 上 ， 作 为 URL 的 一 部 分 
发 送 到 服务 器 端 ， 这 种 方式 就 类 似 于 采用 URL 方式 实现 互动 (后 面 将 会 讲 到 ) ; 而 POST 方式 则 是 将 
表单 中 的 信息 作为 一 个 数据 块 发 送 到 服务 器 端 ， 这 种 方式 不 依赖 URL。 

形式 上 两 者 的 区 别 : 在 实际 应 用 时 ， 两 者 的 区 别 也 是 很 明显 的 。 由 于 GET 方法 提交 的 数据 是 被 附 
加 到 URL 上 发 送 的 ， 所 以 在 地 址 栏 中 将 会 显示 出 用 户 所 输入 的 数据 作为 参数 附加 在 URL 后 面 。 反 之 
由 于 POST 方法 不 依赖 于 URL， 所 以 使 用 POST 方法 传送 数据 时 ， 地 址 栏 只 会 显示 表单 ACTION 所 指 
向 的 URL， 而 不 会 显示 用 户 输入 的 数据 。 

通过 以 上 分 析 可 以 得 知 两 种 方式 的 区 别 。 应 该 在 何 种 情况 下 使 用 何 种 数据 提交 方式 呢 ? 一 般 情况 
下 ， 如 果 用 户 提交 的 信息 不 含 私密 性 的 东西 ， 如 使 用 者 的 用 户 名 等 信息 时 ， 使 用 GET 方式 提交 表单 数 
据 。 反 之 ， 如 果 是 论坛 、 聊 天 室 或 者 其 他 Web 程序 的 登录 页 ， 其 中 包含 使 用 者 的 密码 内 容 ， 这 时 就 一 
定 要 使 用 POST 来 提交 表单 数据 。 


15.1.5 用 PHP 作 后 台 处 理 表单 提交 数据 


YA 知识 点 讲解 ， 光盘 \ 视 频 讲 解 \ 第 15 章 \ 用 PHP 作 后 台 处 理 表单 提交 数据 .wmv 

在 普通 Web 页 中 插入 了 相应 的 表单 元 素 , 为 表单 指定 了 action 属性 ， 并且 也 使 用 了 相应 的 method 
提交 方式 。 这 一 小 节 ， 就 来 创建 对 表单 提交 数据 进行 处 理 的 后 台 程序 。 

表单 提交 后 ， 一 般 的 处 理 是 对 用 户 提 交 的 数据 进行 分 析 。 明 确 要 采取 的 动作 是 要 存 入 文本 文件 或 
者 存 入 数据 库 ， 还 是 对 用 户 提交 的 信息 与 已 经 存在 的 记录 进行 对 比 。 不 过 执行 这 些 动作 的 前 提 是 先 要 
获得 用 户 提交 数据 的 内 容 。 

这 里 要 提 到 php.ini 中 的 global 值 。 在 老 版 本 的 PHP 中 ， 默 认 值 是 开启 的 。 表 现在 php.ini 中 就 是 : 
global=on。 这 样 就 会 存在 一 些 问 题 ， 所 有 用 户 提交 的 变量 ， 都 可 以 当 作 全 局 变量 直接 被 引用 ， 如 用 户 
提交 页 中 有 如 下 一 个 表单 : 

«form method-post action-url» 

请 输入 用 户 名 : «input type=text name-usemame» 


<p> 
请 输入 密码 : <input type=password name=pass> 
<p> 
«input type=submit value=" 确 认 提 交 "> 
</form> 
如 果 此 时 php.ini 中 的 global 值 为 ON， 则 这 些 被 提交 的 变量 Cusemma. pass) 在 目标 页 面 中 都 可 
以 被 直接 引用 。 


如 果 是 这 样 就 会 存在 一 定 的 安全 隐患 。 所 以 在 后 来 的 PHP 版 本 中 ， 该 global 项 都 被 关闭 了 。 如 果 
该 选项 值 为 OFF 的 话 ， 这 些 被 提交 的 变量 就 不 能 被 直接 引用 ， 要 引用 这 些 变量 必须 通过 相应 的 POST 
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ET 数组 。 
上 面 提交 的 表单 在 php.ini 中 的 global 值 为 OFF 时 ， 就 要 这 样 引 用 : $_POST['username']、 


$_POST["pass]。 如 果 method 属性 为 GET， 则 要 这 样 引用 : $ GET['username']. $ GET['pass']. 


以 
准 
[ 


下 讲 到 例子 ， 及 本 书 中 所 有 的 有 关 表单 提交 变量 的 情况 均 采 用 global-OFF 的 值 来 设 定 。 
备 工 作 做 完 ， 就 开始 来 创建 对 实例 15-1 的 处 理 页 面 。 
实例 15-2】 这 里 并 不 对 数据 采取 其 他 处 理 ， 只 是 先 获取 提交 的 内 容 并 显示 出 来 。 


区 实例 15-2. 获取 提交 的 内 容 并 显示 出 来 
| 源码 路 径 : 光盘 \ 源 文件 \15\15-2.php 


01 
02 
03 


«?php 
ifl$ POST[name7) 1/ 判断 有 无 数据 被 提交 
{ 
echo "没有 相应 的 用 户 名 "; 
echo "<p>"; 
echo "点 <a href=15-1.php> 这 里 </a> 返 回 "; 
exit(); // 中 止 所 有 PHP 运行 
H 
else // 如 果 有 数据 提交 ， 则 显示 相应 HTML 
{ 
?» 
«html» 
<head> 
<title> 提 交 表单 的 处 理 示例 </title> 
</head> 
<body> 
<center> 
<h3> 提 交 表 单 处 理 示例 </h3> 
<table border=1> 
<tr> 
«td colspan=2> 以 下 为 用 户 提交 内 容 </td> 
<t> 
<td> 姓 名 : </td> 
<td><?php echo $ POST['name']?» «/td» 
«ftr» 
«tr 
<td> 性 别 : «/td» 
<td><?php echo $ POST['sex]?»«/td» 
«ftr» 
«tr 
<td> 生 日 : </td> 
<td><?php echo $_POST[month]." 月 "$_POSTTdate]" 日 "?></td> 
«ftr» 
«t 
<td> 爱 好 : </td> 
«td» 
<?php 
for($iz0;$i«count($ POST[favior]);Si--) 
t 
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40 echo $ POST[favior'][Si]; 

41 echo", "; 

42 H 

43 ?> 

44 </td> 

45 «hr» 

46 st 

47 <td> 其 他 : </td> 

48 <td> 

49 «?php 

50 Sother-htmlspecialchars($ POST[other']); /去 掉 特殊 字符 
51 $other=ereg_replace("\r\n","<br>",$other); /| 转行 回 车 
52 S$other=ereg_replace("\r","<br>",$other); /| 转行 换行 
53 echo $other; 

54 ?> 

55 </td> 

56 «Ir» 

57 <tr> 

58 <td colspan=2> 

59 <center><a hrefz15-1.php»i& Bl</a></center> 

60 <hd> 

61 </tr> 

62 </table> 

63 </center> 

64 </body> 

65 </html> 

66 <?php 

67 l 

68 za 


在 PHP 运行 环境 下 执行 实例 15-1 的 代码 (记得 在 运行 前 , 要 把 15-1.php 中 form 的 method 属性 设 
Jy POST, action 属性 设 为 15-2.php) 。 按 要 求 完整 填写 相应 信息 ， 然 后 单 击 “确认 提交 ”按钮 ， 执 行 
结果 如 图 15.2 所 示 。 


ESICIT* 
[E rciAocalhosti: D. v Ch | Saa 
提交 表单 处 理 示 例 
以 下 为 用 户 提交 内 容 
Em 
5. [E 
EA: J10H22B 
EF em. Wok. Ej. yeh. WA. 
Et: pera! 
ED 
| uos v 


图 15.2 提交 表单 处 理 的 实例 执行 结果 


从 图 15.2 可 以 发 现 ， 正 确 返 回 了 用 户 提 交 的 各 项 信息 ， 这 是 对 这 些 信 息 进 行 下 一 步 操 作 的 关键 。 
需要 注意 的 是 ， 多 选 框 checkbox 的 值 的 获取 。 在 命名 表单 时 使 用 name[] 这 样 的 形式 。 这 样 在 提交 
时 ,提交 的 内 容 就 会 以 name[0]、name[1]、…、name[n] 的 形式 出 现 。 获 取 时 也 要 使 用 循环 来 遍历 数组 。 


(m, 


use BPHPRSANEE 


15.2. URL 参数 与 PHP 


使 用 URL 参数 ， 也 是 与 用 户 实现 互动 的 一 种 重要 方式 。 不 过 该 种 方式 与 使 用 表单 相 比 的 缺点 也 显 
而 易 见 ， 就 是 可 视 化 及 友好 程度 都 要 差 一 些 。 表 单 使 用 各 种 表单 元 素来 供用 户 进行 输入 信息 或 者 选择 
某 些 选项 ， 而 URL 则 只 能 提供 超 链接 的 形式 来 供用 户 选择 或 者 使 用 某 些 信息 。 同 时 由 于 URL 的 数据 
发 送 方式 与 表单 提交 的 GET 方式 类 似 ， 所 以 使 用 URL 所 附带 的 各 种 参数 都 会 完全 显示 在 浏览 器 的 地 
址 栏 上 。 所 以 ， 它 在 安全 性 方面 也 存在 局 限 性 。 


15.2.1 在 PHP BS URL 地 址 上 加 入 参数 


EB 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 15 EVE PHP 的 URL 地 址 上 加 入 参数 .wmv 

使 用 URL 参数 方式 传递 数据 ， 就 是 在 URL 地 址 后 面 加 上 适当 的 参数 。URL 实体 将 对 这 些 参 数 进 
行 处 理 。 简 单 的 使 用 方法 如 下 所 示 : 

http://127.0.0.1/15-3.php?username=JACK&sex= 男 &age=23 

然后 ， 直 接 在 地 址 栏 中 输入 这 些 内 容 即 可 〈 由 于 还 没有 编写 相应 的 PHP 文件 ， 所 以 现在 执行 还 不 
会 有 任何 如 果 ) 。 

通过 以 上 代码 了 解 到 ， 在 URL 地 址 后 面 加 参数 就 是 要 在 完整 的 URL 后 加 “?” 符 号 。 然 后 是 “ 参 
数 名 称 = 参数 值 ”， 如 上 面 的 “username=JACK”。 多 个 参数 之 间 要 使 用 “&” 符 号 ， 它 表示 参数 与 参 
数 之 间 的 连接 。 


15.2.2 ”用 PHP 处 理 提交 的 参数 


(E 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 15 EUA PHP 处 理 提交 的 参数 .wmv 

前 面 在 介绍 表单 的 提交 方式 时 曾 提 到 过 : 采用 表单 的 GET 提交 方式 提交 的 数据 被 附加 到 URL E, 
作为 URL 的 一 部 分 发 送 到 服务 器 端 。 这 种 方式 就 类 似 于 采用 URL 方式 实现 互动 。 所 以 对 于 采用 URL 
参数 方式 提交 表单 数据 的 获取 也 采用 $_GET[' 参 数 名 称 "] 的 方式 来 获取 。 

如 下 面 的 : 

http://127.0.0.1/15-3.php?username=JACK&sex= 男 &age=23 


调用 时 就 可 以 采用 $_GET['usernma']、$_GET['sex]、$_GET['age"] 来 获取 。 
【实例 15-3】 以 下 代码 演示 处 理 用 户 以 URL 加 参数 形式 提交 内 容 的 PHP 页 面 。 


d < 实例 15-3， 处 理 用 户 以 URL 加 参数 形式 提交 内 容 的 PHP 页面 
源码 路 径 : 光盘 \ 源 文件 \15\15-3.php 


01 <?php 
02 if$ GET['usemame ) 1/ 判断 有 无 数据 被 提交 
03 


{ 
04 echo "没有 相应 的 用 户 名 "; 


8) 
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05 echo "<p>"; 

06 exit(); /中 止 所 有 PHP 运行 
07 } 

08 else // 如 果 有 数据 提交 ， 则 显示 相应 HTML 
09 

10 ?> 

11 «html» 

12 <head> 

13 «title»3& 3: URL 参数 的 处 理 实例 </title> 
14 </head> 

15 <body> 

16 <center> 

17 <h3> 提 交 URL 参数 处 理 实例 </h3> 
18 <table border=1> 

19 <tr> 

20 <td colspan=2> 以 下 为 用 户 提交 内 容 </td> 
21 <tr> 

22 <td> 姓 名 : </td> 
23 <td><?php echo $ GET['username]?»«/td» 
24 «tr» 

25 <tr> 

26 <td> 性 别 : </td> 
27 <td> 

28 «?php 

29 i$ GETI ser) 

30 echo $ GET['sexT; 

31 else 

32 echo "没有 相应 的 性 别 "; 

33 ?> 

34 </td> 

35 <hr> 

36 <tr> 

37 <td> 年 龄 :</td> 
38 «td» 

39 «?php 

40 iS GET['age]) 

41 echo $ GET['age]; 

42 else 

43 echo "没有 相应 的 年 龄 "; 

44 ?> 

45 </td> 

46 <hr> 

47 </table> 

48 </center> 

49 </body> 

50 </html> 

51 <?php 

52 ) 

53 ?> 


在 PHP 运行 环境 中 执行 以 上 代码 ， 将 输出 如 图 15.3 所 示 的 执行 结果 。 


@ 


sise BPHPRSAHRE KA 
[€] 9 E hnpy/localhosv1= £ 


~| 


没有 相应 的 用 户 名 ^ 


A19 ~ 


图 15.3 提交 URL 参数 的 处 理 实例 (无 参数 ) 执行 结果 
为 什么 会 这 样 ? 因为 上 面 的 代码 使 用 了 有 无 参数 提交 的 判断 ， 而 在 执行 时 并 没有 附加 任何 参数 ， 
所 以 才 会 出 现 如 图 15.3 所 示 的 执行 结果 。 下 面 带 参数 再 运行 一 次 ， 在 地 址 栏 中 输入 下 面 的 内 容 
http://127.0.0.1/15-3.php?username-JACK&sex- S &age-23 
执行 结果 如 图 15.4 所 示 。 


以 下 为 用 户 提交 内 容 | 


于 


154 提交 URL 参数 的 处 理 实例 (有 参数 ) 执行 结果 


通过 图 15.4 可 以 发 现 ， 在 加 上 相应 的 参数 之 后 ， 程 序 正确 显示 出 了 用 户 所 提交 的 内 容 ， 实 现 了 互 
动 的 目的 。 


15.3 ”表单 使 用 实例 


GE 知识 点 讲解 ， 光盘 \ 视 频 讲解 \ 第 15 章 \ 表 单 使 用 实例 .wmv 

本 节 通 过 一 个 实例 来 向 读者 介绍 如 何 使 用 表单 。 与 前 面 几 小 节 介绍 的 不 同 ， 本 节 的 实例 将 会 把 表 
单 输入 的 前 台 与 表单 数据 处 理 的 后 台 整合 在 一 个 文件 之 中 。 把 表单 相关 的 前 台 与 后 台 整合 起 来 ， 一 方 
面 可 以 减少 文件 个 数 ， 另 一 方面 也 更 便于 管理 ， 而 且 当 文件 需要 移动 时 ， 只 用 移动 一 个 文件 即 可 。 

该 实例 实现 如 下 功能 ， 当 有 用 户 表单 提交 操作 时 ， 把 用 户 所 输入 的 表单 内 容 存 放 到 一 个 以 该 用 户 
所 输入 的 用 户 名 为 文件 名 的 文本 文件 中 。 

【实例 15-4】 以 下 为 表单 使 用 实例 代码 。 


re O RAISA: 表单 使 用 实例 
源码 路 径 : 光盘 '\ 源 文件 \1S\15-4.php 


?php 
02 if(l$_POST[name]) 1/ 判断 有 无 数据 被 提交 


03 { // 如 果 没 有 数据 被 提交 ， 显 示 提交 表单 内 容 
04 ?> 


05 «html» 
06 «head» 
07 <title> 表 单 使 用 实例 </title> 


.9 


PHP 网 络 编程 技术 详解 


08 </head> 

09 <body> 

10 <center> 

11 <h3> 表 单 使 用 实例 </h3> 

12 «p» 

13 «table border=1> 

14 «form method-post action «?phpecho $PATH INFO?»» 
15 <tr> 

16 <td> 姓 名 : </td> 

17 <td><input type=text name="name" size="12"></td> 
18 <tr> 

19 <tr> 

20 <td> 性 别 : </td> 

21 <td> 

22 «input type=radio name=sex value=" 男 " checked> 男 
23 «input type=radio name=sex value=" 女 "> 女 
24 </td> 

25 «itr» 

26 <tr> 

27 «td» £H: </td> 

28 <td> 

29 <select name=month> 

30 <option value=1>1</option> 
31 <option value=2>2</option> 
32 <option value=3>3</option> 
33 <option value=4>4</option> 
34 <option value=5>5</option> 
35 <option value=6>6</option> 
36 <option value=7>7</option> 
37 <option value=8>8</option> 
38 <option value=9>9</option> 
39 <option value=10>10</option> 
40 «option value=11>11</option> 
41 <option value=12>12</option> 
42 </select> H 

43 <select name=date> 

44 <option value=1>1</option> 
45 <option value=2>2</option> 
46 <option value=3>3</option> 
47 <option value=4>4</option> 
48 <option value=5>5</option> 
49 <option value=6>6</option> 
50 <option value=7>7</option> 
51 <option value=8>8</option> 
52 <option value=9>9</option> 
53 <option value=10>10</option> 
54 «option value=11>11</option> 
55 <option value=12>12</option> 
56 «option value=13>13</option> 
57 «option value214»14«/option? 
58 <option value=15>15</option> 
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59 

60 

61 

62 

63 

64 

65 

66 

67 

68 

69 

70 

71 

72 

73 

74 

75 

76 

77 «ftr» 
78 <tr> 
79 

80 

81 

82 

83 

84 

85 

86 

87 

88 

89 

90 «itr» 
91 <tr> 
92 

93 

94 

95 

96 «itr» 
97 <tr> 
98 

99 

100 

101 

102 

103 

104 </tr> 
105 </form> 
106 </table> 

107 </center> 

108 </body> 

109 </html> 


</td> 


<option value=16>16</option> 
<option value=17>17</option> 
<option value=18>18</option> 
<option value=19>19</option> 
<option value=20>20</option> 
<option value=21>21</option> 
<option value=22>22</option> 
<option value=23>23</option> 
<option value=24>24</option> 
<option value=25>25</option> 
<option value=26>26</option> 
<option value=27>27</option> 
<option value=28>28</option> 
<option value=29>29</option> 
<option value=30>30</option> 
<option value=31>31</option> 


</select> 日 


<td> 爱 好 : </td> 


<td> 
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«input type=checkbox name=favior[] value=" 旅 游 "> 旅游 
«input type=checkbox name-favior[] value=" 运 动 "> 运动 
«input type=checkbox name-favior[] value=" 看 电影 "> 看 电影 <p> 
«input type=checkbox name-favior[] value=" 游 戏 "> 游戏 
«input type=checkbox name=favior[] value=" 上 网 "> 上 网 
«input type=checkbox name=favior[] value=" 听 音乐 "> 听 音 乐 <p> 
«input type=checkbox name=favior[] value=" 登 山 "> 登山 
«input type=checkbox name=favior[] value=" 聊 天 "> 聊天 


«ftd» 


<td> 其 他 : </td> 


<td> 


<textarea cols=24 rows=5 name=other></textarea> 


«ftd» 


<td colspan-"2"» 
«center» 


«input type-submit value=" 提 交 "> 
«input type-reset value=" 重 置 "> 


</center> 


«ftd» 
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110 <?php 


111 
112 
113 
114 
115 
116 
qr 


132 
133 
134 
135 
136 
137 ?> 


) 


else 


ü 


) 


/如 果 有 数据 提交 ， 则 执行 相关 操作 


$name-$ POST[name]; 

$sex-$ POST[sex?; 

$birthday-$ POST['month]."H".$ POST[date]."R"; 
for($i-0;Si«count($ POST[favior]);Si--) 


$f-$f.$ POST[favior][Si]."*"; 


H 

Sother-htmlspecialchars($ POST[^other]); /去 掉 特殊 字符 
$other=ereg_replace("\r\n","<br>",$other); /| 转行 回 车 
S$other=ereg_replace("\r","<br>",$other); /| 转行 换行 
$s=$name."".$sex." ".$birthday." ".$f." "".Sother."n"; 
$myfile=fopen($name,"w"); /创建 文件 
fwrite($myfile,$s); // 置 入 相应 内 容 
fclose($myfile); /| 关闭 文件 


echo "用 户 输入 内 容 为 :"; 

echo $name."<p>"; 

echo $sex."<p>"; 

echo $birthday."<p>"; 

echo $f."«p»"; 

echo $other; 

echo "«p»"; 

echo "用 户 文件 已 经 创建 完毕 ! ns 


在 PHP 执行 环境 中 运行 该 PHP 文件 ， 将 会 出 现 与 实例 15-1 基本 类 似 的 执行 结果 ， 因 为 它们 采用 
的 前 台 内 容 及 格式 基本 上 是 相同 的 。 
在 执行 界面 上 的 表单 中 输入 相应 内 容 ， 这 里 输入 以 下 内 容 〈 读 者 也 可 以 根据 自己 喜好 ， 输 入 相应 


内 容 ) : 


姓名 : JACK; 性 别 : 男 ; 生日 : 11 月 5 日; 爱好 : 运动 + 看 电影 + 听 音 乐 + 登山 其 他 : 该 同志 为 美 籍 华人 。 现 住 
美国 纽约 市 。 


输入 完毕 后 ， 单 击 “ 提 交 ” 按 钮 ， 将 会 出 现 如 图 15.5 所 示 的 执行 结果 。 
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[rem 


[€] ED 


用 户 答 和 内容 为 ，JACK 

男 

1A58 

运动 + 在 电影 - 听 音 乐 + 登 山 + 


图 15.5 表单 使 用 实例 处 理 结果 
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从 图 15.5 的 执行 结果 可 以 发 现 ， 程 序 正 确 显 示 出 了 用 户 输入 的 各 项 内 容 ， 并 且 还 提示 用 户 文件 已 
经 创建 完毕 。 

然后 到 15-4.php 所 在 目录 里 能 够 发 现 名 为 JACK 的 文件 ， 用 记事 本 打开 它 ， 里 面 有 以 下 内 容 

JACK“ B11 月 5 日 运动 + 看 电影 + 听 音 乐 + 登山 + 该 同志 为 美 籍 华人 。\<br /> 现 住 美国 纽约 市 。 


说 明 用 户 文件 已 经 被 正确 创建 。 

这 个 表单 使 用 的 实例 就 为 读者 介绍 到 这 里 。 具 体 使 用 中 Web 表单 还 有 更 多 的 用 途 ， 如 把 用 户 记录 
存 入 数据 库 、 获 得 用 户 提交 信息 与 库 中 内 容 相 比 较 、 通 过 用 户 提交 表单 执行 相关 操作 等 。 可 以 说 ， 表 
单 的 使 用 非常 广泛 。 所 以 只 有 熟练 掌握 了 表单 的 使 用 ， 才 能 开发 出 高 效 的 人 机 交互 Web 程序 。 


15.4 A €x 


实现 人 机 交互 是 动态 网 页 技术 的 重要 特点 之 一 。 本 章 主要 介绍 用 PHP. 实现 人 机 交互 的 两 种 方式 : 
表单 方式 和 URL 参数 方式 。 其 中 表单 方式 常用 于 论坛 中 的 用 户 注 册 、 用 户 登录 信息 录入 等 ， 而 URL 
参数 方式 多 见于 留言 本 中 的 分 页 显示 、 论 坛 中 的 分 主题 显示 、 论 坛 中 不 同 子 论坛 之 间 的 跳 转 等 。 可 以 
说 ， 两 种 方式 都 有 着 广泛 的 应 用 ， 并 且 它 们 各 有 其 优 缺 点 ， 互 为 补充 。 

通过 本 章 对 两 种 实现 人 机 交互 方式 的 学 习 , 及 对 具体 使 用 实例 的 介绍 , 相信 读者 对 于 如 何 通过 PHP 
代码 实现 人 机 交互 会 有 一 个 深刻 的 认识 ， 从 而 为 写 出 高 效率 的 Web 应 用 程序 打下 坚实 的 基础 。 

编写 人 机 交互 程序 有 一 个 问题 需要 引起 读者 的 注意 ， 那 就 是 要 了 解 php.ini 中 global 的 状态 ， 对 于 
该 值 不 同 的 状态 采用 不 同 的 变量 获取 形式 。 
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计数 器 在 网 络 上 的 运用 非常 广泛 ， 比 较 常 见 的 应 用 的 是 访客 浏览 量 计数 器 。 在 网 站 里 放置 一 个 访 
客 浏览 量 计数 器 ， 可 以 帮助 站 长 了 解 站 点 的 访问 情况 。 本 章 就 来 介绍 怎样 使 用 PHP 来 开发 计数 器 小 程 
序 ， 主 要 包括 简单 计数 器 (计数 器 原理 、 计 数 器 算法 的 设计 、 具 体 代 码 实现 计数 器 ) 、 图 形 化 计数 器 
(设计 算法 、 用 图 片 替 换文 本 、 代 码 实 现 ) 、 添 加 “防止 恶意 刷新 ”功能 和 多 用 户 计数 器 等 内 容 。 


16.1 简单 计数 器 


计数 器 的 功能 虽然 单一 ， 但 根据 存储 及 表现 方式 的 不 同 也 有 多 种 多 样 。 有 简单 的 文本 计数 器 、 在 
文本 计数 器 基础 上 的 图 形 计数 器 、 以 数据 库 为 基础 的 数据 库 计 数 器 等 。 本 节 先 来 介绍 简单 的 文本 计 
数 器 。 


16.1.1 ”计数 器 的 原理 


F 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 16 章 \ 计 数 器 的 原理 .wmv 

计数 器 的 原理 很 简单 ， 就 是 累加 。 如 果 原 始 值 是 0， 就 在 0 的 基础 上 累加 1， 结 果 就 是 1。 每 浏览 
一 次 就 在 原来 浏览 量 的 基础 上 累加 1。 

既然 是 简单 的 文本 计数 器 ， 就 采用 文本 文件 作为 裁 体 。 第 一 次 运行 程序 时 ， 先 判断 有 没有 相应 的 
文本 文件 ， 如 果 没有 就 创建 文件 ， 并 置 入 0。 以 后 程序 运行 时 ， 先 读 出 文本 文件 中 存储 的 数值 ， 把 原 值 
自 增 1 再 把 增加 的 值 显示 出 来 ， 然 后 把 增加 的 值 重 新 写 入 文本 文件 即 可 。 


16.1.2 ”设计 算法 


颁 1 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 16 章 \ 设 计算 法 ( 简单 计数 器 ) wmv 

把 文本 文件 名 定义 给 变量 。 先 判断 文件 是 否 存 在 ， 这 里 要 用 到 fileexists() 函 数 。 如 果 不 存 在 ， 使 用 
读 写 方式 创建 文件 ， 这 里 要 使 用 open(" 文 件 名 ","a") 函 数 ， 并 置 入 0， 这 里 要 使 用 fwrite() 函 数 。 然 后 使 
用 file(" 文 件 名 ") 函 数 读 出 文件 数据 内 容 ， 给 原 值 加 1。 使 用 echo 函数 显示 到 用 户 界面 ， 青 把 增加 过 的 
值 重新 写 入 文本 文件 ， 关 闭 文件 结束 程序 。 


16.1.3 ”代码 实现 


GH 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 16 章 \ 代 码 实现 ( 简单 计数 器 ) wmv 
【实例 16-1】 下 面具 体 来 实现 16.1.2 小 节 中 所 要 求 的 功能 。 


wie yasen AA 


re 实例 16-1: 具体 代码 实现 
源码 路 径 光盘 \ 源 文件 \16\16-1.php 


01 <html> 

02 <head> 

03 «title» PHP 文本 计数 器 </title> 

04 </head> 

05 <body> 

06 <?php 

07 $c file-"counter.txt"; /文件 名 赋值 给 变量 
08 if(ffile exists(Sc file) // 如 果 文件 不 存在 的 操作 
09 ( 

10 $myfile-fopen(Sc file,"w"); // 创 建文 件 

11 fwrite($myfile,"0"); 1// 置 入 0 

12 fclose($myfile); /关闭 文件 

13 ) 

14 $t num-file($c file); /把 文件 内 容 读 入 变量 
15 $t_num[0]++; /文件 内 容 自 增 1 

16 echo "欢迎 ! 您 是 本 站 第 ".$t_num[0]." 位 访客 ! "; /显示 文件 内 容 

17 $myfile-fopen($c file,"w"); /打开 文件 

18 fwrite($myfile,$t_num[0]); // 写 入 新 内 容 

19 fclose($myfile); /关闭 文件 

20 ?> 

21 </body> 

22 </html> 

在 PHP 运行 环境 中 执行 以 上 PHP 文件 ， 第 一 次 运行 的 执行 结果 如 图 16.1 所 示 。 
同时 打开 程序 运行 的 文件 夹 ， 会 发 现 多 了 一 个 名 为 counter.txt 的 文件 ， 说 明 程序 正常 运行 。 


刷新 该 页 面 ， 相 当 于 程序 重新 加 载 一 次 ， 执 行 结果 如 图 16.2 所 示 。 


[€] @ itpi/localhost/1t £ 


Q —- 
欢迎 ! 您 是 本 站 第 1 位 访客 ! 

图 16.1 文本 计数 器 第 一 次 运行 的 执行 结果 图 162 文本 计数 器 第 二 次 运行 的 执行 结果 
说 明 程序 已 经 正常 运行 ， 并 已 经 能 实现 累加 ， 经 得 起 多 次 考验 。 

本 节 简 单 文本 计数 器 就 介绍 到 这 里 ，16.2 节 将 介绍 图 形 化 计数 器 。 


欢迎 ! 您 是 本 站 第 2 位 访客 ! 


^i* v 


162 ”图形 化 计数 器 


文本 计数 器 虽然 简单 易 行 ， 但 是 美观 程度 上 要 欠缺 一 点 。 如 果 采 用 图 形 的 方式 来 表达 计数 器 内 容 ， 
就 既 能 实现 计数 功能 ， 又 让 人 印象 深刻 。 本 节 就 来 讲解 在 PHP 中 怎样 在 文本 计数 器 的 基础 上 实现 图 形 
化 的 计数 器 。 


KI 


M ea 


16.2.1 设计 算法 〈 图 形 化 计数 器 ) 


EB 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 16 章 \ 设 计算 法 ( 图形 化 计数 器 ) wmv 


图 形 计数 器 是 在 文本 计数 器 的 基础 上 建立 起 来 的 ， 它 们 的 算法 是 完全 相同 的 ， 都 是 简单 的 累加 。 
不 同 的 是 ， 文 本 计数 器 只 是 把 文本 内 容 简 单 地 表现 给 用 户 ， 而 图 形 计 数 器 则 是 采用 图 片 的 方式 来 表达 


文本 的 内 容 。 
1622 ”用 图 片 替代 文本 


GE 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 16 章 \ 用 图 片 兰 代 文本 .wmv 


在 讲解 本 小 节 实现 图 形 化 计数 嚣 之前， 请 先 准 备 内 容 为 0~9 的 10 张 小 图 片 ， 文 件 名 要 与 内 容 一 


致 ， 分 别 为 0.gif、1.gif*…8.gif、9.gif。 


要 实现 图 片 蔡 代 文本 ， 一 位 数 不 会 出 现任 何 问题 ， 但 是 超过 一 位 就 有 麻烦 了 ， 总 不 能 再 准备 11 一 
99 的 图 片 吧 。 所 以 要 把 文本 逐个 分 开 ， 再 分 别 用 相应 的 图 片 来 替换 。 这 样 的 话 ，file() 函 数 就 不 能 满足 
需要 了 ， 因 为 它 是 把 文件 按 行 读 入 数组 。 所 以 这 里 要 采用 getc() 函 数 ， 因 为 这 个 函数 是 按 字符 来 读 取 文 


件 内 容 的 。 
16.2.3 ”代码 实现 (图 形 化 计数 器 ) 


WA 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 16 ERGER ( 图 形 化 计数 器 ) wmv 


本 小 节 具 体 讲 解 怎么 用 代码 来 实现 图 形 化 计数 器 ， 同 时 也 来 对 比 一 下 file0 与 gete0 函 数 的 区 别 。 
【实例 16-2】 以 下 代码 为 实现 图 形 化 计数 器 。 


实例 16-2: 实现 图 形 化 计数 器 — 
源码 路 径 ， 光 盘 \ 源 文件 \16\16-2.php 


02 <head> 

03 ”<title>PHP 图 形 化 计数 器 </title> 
04 </head> 

05 <body> 

06 <?php 

07 $c file-"counter.txt"; 

08 if(Ifile exists(Sc file) 

09 { 

10 $myfilezfopen(Sc file,"w"); 
11 fwrite($myfile,"0"); 

12 fclose($myfile); 

13 ) 

14 $t num-file(Sc file); 

15 $t num[0]; 

16 $myfile-fopen($c file,"w"); 
17 fwrite($myfile,$t num[0]); 
18 fclose($myfile); 
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/文件 名 赋值 给 变量 
// 如 果 文 件 不 存在 的 操作 


/创建 文件 
BAO 
/关闭 文件 


/把 文件 内 容 读 入 变量 
// 原 始 数据 自 增 1 

// 写 入 方式 打开 文件 
// 写 入 新 数值 

/关闭 文件 


4165 计数 器 程 


19 echo "欢迎 ! 您 是 本 站 第 "; // 显 示 内 容 头 部 

20 $myfile-fopen(Sc file,"r"); /以 只 读 方式 打开 文件 
21 while(!feof($myfile)) /| 循环 读 出 文件 内 容 

22 ü 

23 $numzfgetc($myfile); // 当 前 指针 处 字符 赋值 给 变量 
24 if($num) /如果 数值 存在 执行 操作 
25 fi 

26 echo "<img srczimagesW".$num.".gif2"; /显示 相应 图 片 

27 H 

28 H 

29 fclose($myfile); /关闭 文件 

30 echo "位 访客 ! "; /显示 内 容 尾 部 

31 7?» 

32 </body> 

33 </html> 


在 PHP 运行 环境 下 执行 这 个 PHP 文件 ， 执 行 结果 如 图 16.3 所 示 。 


[€] Je httpi//localhost/1€ O 


欢迎 ! 您 是 本 站 第 1 位 


图 16.3 图 形 化 计数 器 执行 结果 
该 计数 器 程序 在 1 位 数 的 情况 下 能 够 正常 运行 ， 下 面 持续 刷新 ， 直 到 该 计数 器 达到 9 以 上 ， 执 行 
结果 如 图 16.4 所 示 。 


er 


E htp//ocalhosie D ~ ( 


欢迎 ! 您 是 本 站 第 11 位 访客 ! 


R100% ~ 


图 16.4 图 形 化 计数 器 在 浏览 量 超过 两 位 时 的 执行 结果 


执行 结果 表明 ， 即 使 是 在 浏览 量 为 两 位 的 情况 下 ， 该 计数 器 程序 依然 是 经 得 起 考验 的 。 
通过 本 小 节 的 介绍 ， 一 个 既 简 单 又 美观 的 图 形 化 计数 器 已 经 完成 了 。 还 可 以 去 掉 代码 中 的 HTML 
部 分 ， 只 保留 PHP 代码 ， 这 样 就 可 以 在 其 他 PHP 页 面 中 引用 这 个 文件 了 。 


16.3 添加 “防止 恶意 刷新 ”功能 


虽然 现在 已 经 实现 了 计数 器 的 功能 ， 但 是 有 一 点 不 太 完美 ， 就 是 每 当 用 户 刷 新 一 下 就 会 使 计数 器 
运行 一 次 。 这 样 获得 的 情况 往往 不 太 准 确 ， 因 为 可 能 有 别有用心 的 人 会 不 停 地 刷新 ， 以 达到 计数 器 疯 
狂 增 加 的 目的 。 怎 么 样 避 免 这 种 状况 发 生 呢 ? 这 里 就 要 用 到 功能 强大 的 Cookie 了 。 本 节 来 讲解 怎样 通 


过 Cookie 来 完善 图 形 化 计数 器 。 
KJ! 


(0 PHPHBARE RR UR 


16.3.4. 设计 算法 (添加 “防止 恶意 刷新 ”功能 ) 


EB 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 16 章 \ 设 计算 法 (添加 “防止 恶意 刷新 ”功能 ) wmv 

防 刷新 功能 的 算法 如 下 : 先 判断 有 没有 Cookie， 如 果 没有 Cookie 就 启动 一 次 计数 器 并 且 写 入 当天 
系统 日 期 到 Cookie 数据 。 当 用 户 刷新 或 者 第 二 次 浏览 时 ， 就 判断 Cookie 数据 是 否 与 系统 日 期 一 致 ， 
如 果 两 者 一 致 则 只 读 出 原始 数据 ， 并 不 执行 自 增 这 一 步 。 这 样 不 论 用 户 如 何 刷新 ， 计 数 器 就 只 能 够 显 
示 ， 而 不 能 增加 了 。 


16.3.2 ”代码 实现 〈 添 加 “防止 恶意 刷新 ”功能 ) 


FH 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 16 章 \ 代 码 实现 (添加 “防止 恶意 刷新 ”功能 ) wmv 

本 小 节 将 通过 具体 的 代码 来 实现 增强 版 的 计数 器 ， 通过 此 实例 也 能 加 深 读者 对 Cookie 的 认识 。 由 
于 setcookie 在 使 用 之 前 不 能 有 任何 的 输出 操作 , 所 以 本 小 节 的 代码 要 对 16.2 节 的 图 形 化 计数 器 代码 做 
较 大 改动 。 

【实例 16-3】 以 下 代码 为 防止 恶意 刷新 的 计算 器 程序 。 


实例 16-3， 防 止 恶意 刷新 的 计算 器 程序 
-源码 路 径 :光盘 \ 源 文件 \16\16-3.php — 


01 <?php 

02 $c file="counter.txt"; /文件 名 赋值 给 变量 

03 if(file exists(Sc. file) // 如 果 文 件 不 存在 的 操作 
04 $ 

05 $myfile=fopen($c_file,"w"); /创建 文件 

06 fwrite($myfile,"0"); IBA O 

07 fclose($myfile); /关闭 文件 

08 H 

09 $t num-file(Sc file); // 把 文件 内 容 读 入 变量 

10 if($_COOKIE["date"]!=date('Y 4£ m A d Bi) /| 判断 Cookie 内 容 与 当前 日 期 是 否 一 至 
11 

12 $t_num[0]++; /原始 数据 自 增 1 

13 $myfile=fopen($c file,"w"); // 写 入 方式 打开 文件 
14 fwrite($myfile,$t num[0]); // 写 入 新 数值 

15 fclose($myfile); /关闭 文件 

16 setcookie("date",date("Y 年 m 月 d 日 "),time()+60*60*24); // 重 新 将 当前 日 期 写 入 Cookie 并 设 定 
Cookie 的 有 效 期 为 24 小 时 

I7 } 

18 3> 

19 «html» 

20 <head> 

21 «title» PHP 图 形 化 计数 器 </title> 

22 </head> 

23 <body> 

24 <?php 

25 echo "欢迎 ! 您 是 本 站 第 "; /显示 内 容 头 部 

26 $myfilezfopen($c file,"r"); /以 只 读 方式 打开 文件 
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27 while(Ifeof($myfile)) // 循 环 读 出 文件 内 容 

28 { 

29 $num=fgetc($myfile); // 当 前 指针 处 字符 赋值 给 变量 
30 if($num) // 如 果 数 值 存在 执行 操作 
31 ( 

32 echo "<img src=images\\". $num.".gif>"; /显示 相应 图 片 

33 n 

34 } 

35 fclose($myfile); /关闭 文件 

36 echo "位 访客 ! "; /显示 内 容 尾 部 

37 ?» 

38 </body> 

39 </html> 


在 PHP 运行 环境 中 执行 以 上 代码 ， 会 发 现 虽 然 第 一 次 能 正确 显示 ， 但 当 刷 新 页 面 的 时 候 ， 显 示 的 
还 是 原来 的 值 。 因 为 第 二 次 执行 时 Cookie 中 的 值 与 当前 日 期 一 致 ， 程 序 并 不 执行 自 增 操作 ， 所 以 显示 
的 还 是 原始 值 。 至 此 ， 增 强 型 的 防 恶 意 刷新 计数 器 完成 。 


16.4 多 用 户 计 数 器 


在 网 上 经 常 能 找到 面向 多 用 户 的 计数 器 。 任 何人 都 可 以 注册 一 个 用 户 名 ， 然 后 系统 给 出 一 段 
SCRIPT 代码 , 只 要 把 代码 贴 到 自己 的 页 面 上 就 可 以 实现 计数 器 功能 。 那 么 怎样 才能 实现 多 用 户 的 计数 
器 呢 ? 本 节 就 来 介绍 如 何在 PHP 环境 中 编写 多 用 户 计数 器 。 


16.4.1 多 用 户 计数 器 的 原理 


GE 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 16 章 \ 多 用 户 的 原理 .wmv 

要 想 实现 多 用 户 计数 器 ， 就 要 有 多 个 记录 ， 并 且 各 个 记录 之 间 要 互 不 影响 。 访 问 其 中 一 个 用 户 的 
记录 ， 只 在 此 用 户 的 原 有 记录 上 自 增 ， 然 后 重新 保存 在 该 用 户 记录 里 即 可 。 这 样 就 可 以 实现 多 用 户 计 
数 器 了 。 


164.2 ”实现 方法 


YA 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 16 章 \ 多 用 户 计数 器 实现 方法 .wmv 

通常 有 两 种 方法 可 以 实现 多 用 户 计 数 器 。 实 际 上 也 就 是 两 种 存储 机 制 的 问题 : 

采用 文本 文件 作为 存储 载体 。 每 个 用 户 记录 对 应 一 个 文本 文件 。 第 一 次 访问 时 先 判断 该 用 户 
的 文件 是 否 存在 ， 如 果 不 存在 就 创建 文件 并 写 入 0。 如 果 文 件 存在 就 读 出 原 值 并 自 增 1。 显 示 
新 值 ， 把 自 增 后 的 值 写 入 用 户 文件 即 可 。 

ED ”采用 数据 库 作为 存储 载体 。 每 个 用 户 对 应 表 里 的 一 条 记录 。 记 录 内 容 为 相应 的 用 户 及 访问 量 。 
第 一 次 访问 时 先 判断 表 中 有 无 该 用 户 的 记录 , 如 果 没 有 就 写 入 记录 并 初始 化 访问 量 为 0。 如 果 
记录 存在 就 读 出 记录 中 访问 量 的 值 并 自 增 1。 显示 出 新 值 , 再 把 自 增 后 的 值 写 入 表 中 用 户 记录 


即 可 。 
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说 明 : 关于 采用 文本 文件 作为 存储 载体 的 实现 ,与 前 面 介绍 的 例子 差不多 ， 只 是 多 了 一 个 文件 名 的 判 


断 。 这 里 不 再 多 介绍 ， 有 兴趣 的 读者 可 以 自己 研究 ， 这 里 重点 介绍 采用 数据 库 作 为 存储 载体 的 
实现 。 


16.4.3 ”代码 实现 


G8 知识 点 讲解 :光盘 \ 视 频 讲 解 \ 第 16 章 \ 多 用 户 计数 器 代码 实现 .wmv 
本 小 节 将 通过 具体 的 代码 来 介绍 数据 库 版 的 面向 多 用 户 计 数 器 。 通 过 此 实例 也 能 加 深 读 者 对 数据 


库 的 操作 。 由 于 要 用 到 数据 库 、 表 , 所 以 要 先 在 库 里 创建 表 counter。 表 应 包含 字段 id. username. count 


第 一 步 ， 运 行 实例 16-4 来 创建 数据 表 。 
【实例 16-4】 以 下 代码 用 来 创建 mysql X. 


01 <?php 

02 $myconnzmysql connect("localhost","root","admin"); /| 连接 到 服务 器 

03 mysql_select_db('test', $myconn); /| 连接 到 test Æ 

04 $query="create table counter (id int(5) not null auto increment primary key,username varchar(20) not 
null,count int(5) not null default 0)"; /创建 counter 表 语 句 

05 mysql_query($query); /| 执行 语句 

06 mysql_close($myconn); /关闭 对 数据 库 的 连接 

07 echo "你 已 经 成 功 创建 数据 表 "; // 创 建成 功 提示 

08 ?> 


先 打开 MySQL 服务 器 ， 然 后 在 PHP 运行 环境 下 执行 以 上 代码 。 如 果 成 功 就 会 输出 创建 数据 表 成 


功 提 示 。 


02 
03 
04 
05 
06 
07 
08 
09 
10 
11 
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13 
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第 二 步 ， 以 下 实例 代码 为 多 用 户 计数 器 的 核心 文件 。 
【实例 16-5】 以 下 代码 为 多 用 户 计数 器 的 核心 文件 。 


01 <?php 

if($_GET["username"]) 

{ 
$username=$_GET["username"]; 
$myconn-mysq| connect('localhost","root" admin"); [DE 
mysql select db(test'$myconn); /连接 到 test Æ 
$sqlstr="select * from counter where usemame-'$usemame"; /查询 用 户 名 语句 
$result=mysql_query($sqlstr) or die(mysql_error(); /执行 查询 语句 
$num=mysql_num_rows($result); /查询 结果 保存 到 变量 
if($num--0) /如 果 结果 为 0， 执行 操作 
d 


$sqlstr-"insert into counter (username) values ('$username")"; // 揪 入 记录 语句 
mysql query($sqlstr) or die(mysql error()); /执行 语句 


wie meses AA 


14 n 
15 $sqlstr-"select count from counter where username-'$username'"; /重新 查询 
16 $result-mysq! query(Ssqlstr) or die(mysql error()); /执行 查询 语句 
17 $count=mysql_fetch_array($result); /| 结果 保存 到 变量 
18 $count[0] -; IAÑ 1 
19 echo $count[0]; /显示 新 结果 
20 $sqlstr="update counter set count=count+1 where username='$username";  // 更 新 数据 表 
21 $resultzmysq! query(Ssqlstr) or die(mysql error()); /执行 更 新 语句 
22 mysql close($myconn); /关闭 数据 库 连接 
23 H 
24 else echo "用 户 名 不 能 为 空 "; 
25 ?> 
在 需要 调用 的 Web 页 中 插入 以 下 代码 : 
<body> 
<head> 
<title> 计 数 器 测试 页 </title> 
</head> 
<a href="http://127.0.0.1/16-5.php?usemame=test"> 测 试 计数 器 </a> 
</body> 


其 中 的 href 中 的 username 为 用 户 名 ， 然 后 再 浏览 用 户 的 普通 Web. 页 面 就 可 以 顺利 执行 ， 执 行 结 
果 如 图 16.5 所 示 。 

这 里 可 以 更 改 usemame 以 验证 是 否 支持 多 用 户 。 更 改 用 户 名 为 test2， 可 以 发 现 执 行 结果 与 用 户 名 
为 test 类 似 ， 只 不 过 又 从 1 开始 计数 。 


bie) 
Q9 
R100% v 
图 16.5 多 用 户 计数 器 测试 执行 结果 图 16.6 多 用 户 计数 器 在 更 改 用 户 后 的 执行 结果 
使 用 phpMyAdmin 打开 数据 库 ， 查 看 test 库 中 的 counter 表 , 发 现 已 经 有 了 两 条 记录 , 一 条 为 test， 
另 一 条 为 test2。 这 就 说 明 多 用 户 计数 器 已 经 完成 。 


165 本 章 小结 


本 章 为 读者 介绍 了 可 以 经 常用 到 的 PHP 计数 器 。 详 细 说 明了 在 PHP 编程 环境 下 , 怎样 开发 计数 器 。 
通过 本 章 学 习 ， 读 者 不 仅 学 到 了 计数 器 的 算法 ， 同 时 也 复习 了 PHP 对 文件 的 操作 、PHP 中 Cookie 的 
使 用 、PHP 对 MySQL 数据 库 的 操作 等 内 容 。 计 数 器 的 功能 虽然 简单 ， 但 要 做 一 个 完善 的 计数 器 ， 是 
要 结合 多 方面 知识 才能 实现 的 。 
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第 17 章 网 上 投票 程序 


投票 程序 在 网 络 中 有 着 广泛 的 应 用 ， 如 对 某 一 个 问题 的 问卷 调查 ， 或 者 网 站 站 长 对 网 站 满意 度 的 
调查 等 。 本 章 将 介绍 如 何 使 用 PHP 制作 一 个 投票 系统 。 通 常 的 投票 系统 按照 数据 存储 机 制 的 不 同 可 分 
为 文本 类 和 数据 库 类 ， 本 章 将 重点 介绍 后 者 。 本 章 内容 包 括 网 上 投票 程序 的 原理 、 数 据 表 的 设计 、 管 
理 页 面 的 编写 、 用 户 提交 内 容 的 处 理 等 。 通过 本 章 的 学 习 , 读者 能 够 轻松 地 使 用 PHP 编写 出 投票 程序 。 


17.1 投票 程序 的 原理 


GERD 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 17 章 \ 投 票 程 序 的 原理 .wmv 

投票 程序 的 实现 方法 其 实 并 不 复杂 ， 通 常 采 用 这 样 的 算法 : 事先 建立 好 投票 项 ， 当 用 户 通过 前 台 
对 某 一 项 〈 适 用 于 单项 选择 ) 或 者 几 项 〈 适 用 于 多 项 选择 ) 投票 项 进行 选择 并 提交 时 ， 后 台 处 理 就 在 
相应 的 记录 上 增加 1。 显 示 投 票 内 容 时 一 并 显示 相应 投票 项 的 记录 情况 。 这 样 就 可 以 实现 一 个 投票 程 
序 了 。 

当然 ， 单 选项 的 计 票 方式 很 简单 ， 每 投 一 票 计数 一 次 即 可 。 不 过 这 里 面 涉及 一 个 问题 ， 那 就 是 关 
于 多 选项 如 何 计 票 的 问题 。 可 以 把 一 次 多 选 的 所 有 选择 项 当 作 一 次 计数 ， 如 一 次 多 选择 了 3 项 ， 就 当 
作 一 次 计数 。 也 可 以 把 一 次 多 选 的 几 项 当 作 几 次 计数 ， 如 一 次 多 选择 了 3 项 内 容 ， 就 当 作 3 次 计数 。 
本 章 的 实例 将 采用 后 一 种 方式 来 计 票 。 


17.2 ”本 实例 的 特点 


D 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 17 章 \ 本 实例 的 特点 .wmv 

本 节 将 介绍 一 个 简单 的 网 上 投票 系统 。 本 系统 大 致 有 如 下 几 个 特点 : 

用 户 可 以 无 限 增 加 投票 项 目 ， 每 个 项 目 可 以 设 定 为 单 选 或 者 多 选 。 

每 个 项 目 也 可 以 自 定义 投票 项 数目 、 投 票 项 内 容 。 

投票 结果 采用 图 片 和 数字 百分比 两 种 方式 显示 ， 用 户 也 可 以 自 定义 每 个 投票 项 的 图 片 颜色 。 
票 显示 采用 JS 方式 调用 ， 所 以 可 以 在 普通 Web 页 里 插入 相应 的 JS 代码 来 显示 。 

可 以 设置 是 否 用 Cookie 保存 投票 人 的 IP 记录 ， 同 时 可 以 设置 是 否 允 许 同一 IP 地 址 的 多 次 投 

票 ， 若 设置 为 不 允许 ， 可 以 防止 重复 投票 。 

以 上 就 是 本 章 所 要 介绍 的 投票 系统 的 主要 特点 ，17.3 节 将 介绍 数据 表 的 结构 及 各 项 内 容 。 


AARAA 


第 17 章 


17.3 投票 实例 数据 表 设 计 


GE 知识 点 讲解 :光盘 \ 视 频 讲 解 \ 第 17 章 \ 投 票 实例 数据 表 设计 .wmv 
数据 表 的 设计 是 一 个 数据 库 应 用 程序 最 为 重要 的 环节 之 一 。 因 为 数据 表 设 计 的 适当 与 否 直 接 关 系 
着 程序 的 运行 效率 ， 良 好 的 、 设 计 合 理 的 数据 表 将 对 程序 的 运行 起 到 事半功倍 的 效果 。 相 反 ， 如 果 数 
据 表 设 计 混乱 ， 那 么 程序 运行 时 要 完成 同一 个 操作 就 需要 执行 更 多 的 指令 。 这 样 程序 运行 就 会 受到 相 


当 大 的 影响 。 


网 上 投票 程序 


说 明 : 为 了 简化 操作 ， 使 程序 更 容易 理解 ， 本 章 的 投票 程序 实例 的 表 采 用 两 个 表 来 设计 。 采 用 两 个 表 
来 包含 整个 系统 的 全 部 信息 势必 比 采 用 一 个 表 设计 要 复杂 ， 但 这 样 会 使 得 思路 清晰 ， 使 读者 更 


容易 理解 。 


本 章 的 投票 程序 实例 共有 投票 项 记录 表 和 投票 项 选择 支 表 两 个 表 ， 具 体 介 绍 如 下 。 


1. 投票 项 记录 表 


表 名 : vote， 共 有 4 个 字段 ， 每 个 字段 及 其 含义 如 表 17.1 所 示 。 


R171 投票 项 记录 表 vote 字段 列表 
内 S 


记录 投票 项 的 ID 号 


投票 项 的 名 称 ， 实 际 上 是 一 个 投票 项 的 标题 

记录 投票 项 的 结果 。 该 字段 存放 投票 的 总 数 。 如 果 投 
票 项 为 单 选项 ， 则 每 有 一 次 投票 ， 该 值 增加 1; 如 果 
投票 项 为 多 选项 , 则 每 有 一 次 投票 ， 该 值 增 加 投票 选 
择 项 的 项 目 数 

记录 投票 项 的 类 型 。 该 字段 保存 投票 类 型 的 标记 。 如 
果 该 值 为 0， 表 示 为 单 选项 ， 如 果 该 值 为 1， 表 示 为 
多 选项 。 在 显示 投票 时 将 调用 该 值 ， 以 确定 显示 的 表 
单元 素 是 radio 还 是 checkbox。 然 后 就 是 在 处 理 投票 
结果 时 调用 该 值 , 如 果 值 是 单 选项 , 则 采用 一 次 计数 ; 
如 果 是 多 选项 ， 则 采用 多 次 计数 


以 上 是 记录 投票 项 的 表 ， 下 面 是 记录 每 一 个 投票 项 的 选择 支 的 表 。 

2. 投票 项 选择 支 表 

表 名 : record， 共 有 5 个 字段 ， 每 个 字段 及 含义 如 表 172 所 示 。 
R172 ”投票 项 选择 支 表 record 字段 列表 


内 容 


其 他 
表 的 主 关键 字 ， 有 自 
动 增加 的 特性 
无 


其 他 


表 的 主 关 键 字 , 有 


记录 投票 项 的 ID 号 ， 以 此 对 每 个 投票 选择 支 进 行 区 别 


自动 增加 的 特性 


记录 该 投票 支 所 对 应 的 vote 中 投票 项 的 ID, 以 表明 该 选 


择 支 属于 哪 一 个 投票 项 
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字 段 名 
R_NAME 字符 型 | 
R NUM 

R_COLOR 


记录 选择 支 的 内 容 ， 实 际 上 存放 一 个 投票 选择 项 的 内 容 | 无 
记录 该 选择 支 的 被 选 结果 ， 存 放 该 选择 支 被 选择 的 次 数 | 无 
记录 该 选择 支 的 显示 颜色 ， 实 际 是 用 相应 的 小 图 片 来 显示 _| 无 


由 于 采用 的 是 两 个 表 设计 ， 所 以 vote 表 中 存放 投票 项 的 总 情况 ， 具 体 每 一 项 内 容 存放 到 record 表 
中 。 这 样 的 表 结构 虽然 比 采用 单一 表 设 计 的 表 稍 显 复杂 ， 但 实际 运行 起 来 ， 却 会 比 采 用 单 表 的 设计 效 
率 更 高 。 


17.4 代码 实现 


本 节 通 过 具体 的 代码 来 一 步 一 步 完 成 这 个 投票 程序 ， 该 投票 程序 由 新 建 投票 项 、 显 示 所 有 投票 项 、 
单一 投票 项 的 JS 显示 、 处 理 提交 的 内 容 等 模块 组 成 。 下 面 分 别 进 行 介绍 。 


17.4.1 准备 工作 


GE 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 17 章 \ 准 备 工作 .wmv 
在 开发 投票 程度 之 前 ， 有 两 项 工作 是 必须 要 事先 完成 的 。 首 先 ， 是 建立 一 个 配置 文件 ， 存 放 程序 
所 要 调用 的 一 些 重要 变量 ， 如 主机 名 、 用 户 名 、 用 户 密码 、 库 名 、 表 名 等 内 容 。 
【实例 17-1】 以 下 代码 用 来 保存 程序 需要 使 用 的 变量 。 
[KD | 实例 17-1， 保 存 程序 需要 使 用 的 变量 
.| 源码 路 径 : 光盘 \ 源 文件 1717-lphbp aaao 


01 <?php 

02 $db_host="localhost"; /主机 名 

03 $db user-"root"; IAPR 

04 $db_pass="admin"; /用 户 密码 

05 $db_name="test"; /操作 库 名 

06 $table_vote="vote"; [E 1 

07 $table record-"record"; DE 2 

08 $re vote-false; /是 否 人 允许 重复 投票 
09 ?> 


其 次 ， 由 于 所 有 操作 都 需要 通过 对 相应 的 表 的 操作 来 完成 ， 所 以 必须 事先 把 表 创 建 好 。 
【实例 17-2】 以 下 代码 用 于 创建 数据 表 。 
区 < | 实例 17-2. 创建 数据 表 

源码 路 径 : 光盘 '\ 源 文件 \17\17-2.php 


01 <?php 

02 require "17-1.php"; // 调 用 配置 文件 

03 $link=mysqlL_connect($db_host$db user,$db pass)or die(mysql error()); // 连 接 主 机 
04 mysql select db($db name,Slink); /选择 数据 库 
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05 $sql="create table $table vote( 

06 id int(5) not null auto increment primary key, 

07 v. name varchar(50) not null, 

08 v. num int(5) not null default 0, 

09 v. type int(1) not null 

10 y: /创建 vote 表 的 SQL 语句 
11 if(mysql_query($sql,$link)) /发 送 SQL 请 求 

12 echo "投票 表 已 经 创建 成 功 ! <p>"; // 如 果 SQL 语句 成 功 执行 显示 信息 
13 else 

14 echo "创建 表 时 出 现 错误 ， 表 未 被 成 功 创建 。<p>"; 

15 $sql="create table $table_record( 

16 id int(5) not null auto_increment primary key, 

17 r id int(5) not null, 

18 r name varchar(50) not null, 

19 r num int(5) not null default 0, 

20 r color int(1) not null 

21 Jua JI record 表 的 SQL 语句 
22 if (mysql. query($sql,Slink)) // 发 送 SQL 请 求 并 做 判断 

23 echo "记录 表 已 经 创建 成 功 ! <p>"; // 如 果 SQL 语句 被 成 功 执行 ， 显 示 创建 成 功 信息 
24 else // 如 果 创 建 表 失败 ， 显 示 信 息 
25 echo "创建 记录 表 时 出 错 ， 记 录 表 未 被 成 功 创建 。<p>"; 

26 7> 


注意 : 应 该 注意 SQL 语句 的 默认 值 设 置 。 
在 PHP 运行 环境 下 执行 该 PHP 文件 ， 执 行 结果 如 图 17.1 所 示 。 


| 投票 夫 已 经 创建 成 功 ! 
记录 表 已 经 创建 成 功 ! 


图 17.1 创建 数据 表 执行 结果 


从 图 17.1 所 示 的 执行 结果 可 以 发 现 ， 相 应 的 表 已 经 被 正确 创建 。 随 着 表 的 创建 完成 ， 编 写 投票 程 
序 的 准备 工作 就 完成 了 。 从 17.4.2 节 开始 就 来 创建 投票 系统 的 各 个 子 模块 。 


17.4.2 创建 显示 所 有 投票 项 的 页 面 


铭 m 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 17 章 \ 创 建 显示 所 有 投票 项 的 页 面 .wmv 

本 节 来 编写 显示 所 有 投票 项 的 页 面 ， 该 页 面 的 作用 是 把 所 有 已 经 存在 的 投票 项 显示 给 管理 者 ， 以 
便于 用 户 对 这 些 投票 项 进行 相应 的 管理 。 

【实例 17-3】 下 面 为 显示 所 有 投票 项 页 面 的 代码 。 


区 实例 17-3， 显示 所 有 投票 项 的 代码 
源码 路 径 : 光盘 '\ 源 文件 \17\17-3.php 
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02 
03 
04 
05 
06 
07 
08 
09 
10 
11 
12 
13 
14 
15 
16 
17 
18 
19 
20 
21 
22 
23 
24 
25 
26 
27 
28 
29 
30 
31 
32 
33 
34 
35 
36 
37 
38 
39 
40 
41 
42 
43 
44 
45 


<head> 


<title> 投 票 程序 一 一 显示 所 有 投票 项 </title> 


</head> 
<body> 
<center> 


<h1> 投 票 程 序 一 一 显示 所 有 投票 项 </h1> 


<p> 


<a href=17-4.php> 添 加 记录 </a> 


<p> 
<?php 


require "17-1.php"; 
S$linkzmysql connect($db host,$db user,$db pass)or die(mysql error()); 


mysql select db($db name,Slink); 
$sql-"select * from $table vote"; 


/连接 主机 选择 数据 库 
// 选 择 所 有 投票 项 记录 


$result=mysql_query($sql, $link); /发 送 SQL 请 求 
$rows=mysql_fetch_array($result); /计算 总 记录 数 
if($rows==0) /如 果 没 有 记录 ， 显 示 内 容 


else 


echo "现在 还 没有 记录 ! "; 


echo 
echo 
echo 
echo 
echo 
echo 
echo 
echo 
echo 
echo 
echo 
echo 
$i-0; 


$sql-"select * from $table vote"; 


/如 果 存 在 记录 ， 显 示 出 记录 


"<table border-'1'»"; 
"etos 

"<td width='10%'>"; 
"cR: 

"</td>"; 

"<td width='80%'>"; 
"名 称 "; 

"</td>"; 

"<td width='10%'>"; 
"&nbsp;"; 

"</td>"; 

"cft": 


/再 次 执行 SQL 请 求 


$result=mysql_query($sql,$link); 
while($row=mysql_fetch_array($result)) // 遍 历 结 果 


{ 


$i++; // 循 环 变量 ， 显 示 数 值 
echo "<tr>"; 

echo "<td>"; 

echo "第 ".$i." 条 "; // 显 示 数 值 

echo "</td>"; 

echo "<td>"; 

echo "<a href=17-6.php?id=".$row['id].">".$row['v_name']."</a>"; 
echo "</td>"; 

echo "<td>"; 

echo "<a href=17-5.php?id=".$row[id]."> 删 除 </a>"; 

echo "</td>"; 

echo "</tr>"; 


53 Y 
54 echo "</table>"; 
55 } 

56 ?> 

57 </center> 

58 </body> 

59 </html> 
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技巧 : 读者 应 该 体会 到 ， 实 例 中 的 PHP 代 码 可 以 很 容易 结合 HTML 代 码 。 


17.4.8 ”创建 添加 投票 记录 页 面 


FH 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 17 章 \ 创 建 添 加 投票 记录 页 面 .-wmv 

本 小 节 来 创建 管理 者 添加 新 的 投票 项 的 页 面 。 当 用 户 执行 该 页 面 后 ， 该 添加 操作 分 三 步 进行 。 第 
一 步 ， 用 户 输入 要 创建 的 投票 项 的 名 称 ， 选 择 投票 子 项 的 条 数 ， 并 选择 该 投票 项 是 多 选 还 是 单 选 。 第 
二 步 ， 要 求 用 户 分 别 输入 每 一 条 投票 子 项 的 内 容 ， 并 选择 每 一 条 子 项 对 应 的 颜色 。 第 三 步 单 击 “ 确 定 ” 


按钮 ， 完 成 所 有 的 创建 工作 。 


技巧 : 由 于 该 文件 整合 了 添加 投票 记录 的 三 步 操作 ， 所 以 要 对 每 一 步 操作 进行 判断 。 这 样 把 所 有 操作 整 
合 起 来 虽然 会 使 代码 比较 长 ， 但 却 减少 了 文件 的 个 数 ， 更 便于 用 户 对 整个 系统 的 管理 。 


【实例 17-4】 以 下 代码 为 创建 添加 投票 记录 的 页 面 。 


区 1" 实例 17-4， 创 建 添加 投票 记录 的 页 面 
源码 路 径 :光盘 '\ 源 文件 \17\17-4.php， 


01 <?php 
02 if((!$_POST['v_name']) &&(I$ POST[r][1])) 
{ 


04 ?> 

05 «html» 

06 <head> 

07 ”<title> 投 票 程序 一 一 增加 投票 项 第 一 步 </tile> 
08 </head> 

09 <body> 

10 <script language-javascript» 

11 function juge(form) 

1220 

13 if (form.v name.value == "" 


x 
15 alert(" 请 输入 投票 项 名 称 !"); 
16 theForm.v name.focus(); 
17 return (false); 
18 ) 
19 ) 
20 </script> 
21 <center> 


22 ”<h1> 投 票 程序 一 一 增加 投票 项 第 一 步 </h1> 


/没有 任何 参数 为 第 一 步 


(0 PHPBBRUH GR UERE 


23 «p» 

24 ”<h3> 投 票 项 属性 </h3> 

25 <p> 

26 <table border=1> 

27 «form method="post" action=<?php echo $PATH INFO; ?> onsubmit-"return juge(this)"» 
28 <tr> 

29 <td> 输 入 投票 项 内 容 : </td> 

30 <td><input type=text name=v_name></td> 
31 </tr> 

32 <tr> 

33 <td> 选 择 投票 项 的 类 型 </td> 

34 <td> 

35 «input type=radio name=v_type value=0 checked> 单 选 
36 «input type=radio name>v type value=1> 多 选 
37 </td> 

38 </tr> 

39 <tr> 

40 <td> 选 择 投票 项 的 项 数 </td> 

41 <td> 

42 «select name=v_m size=1> 

43 <option value=2>2</option> 

44 <option value=3>3</option> 

45 <option value=4>4</option> 

46 <option value=5>5</option> 

47 <option value=6>6</option> 

48 «option value=7>7</option> 

49 «option value=8>8</option> 

50 «option value=9>9</option> 

51 «option value=10>10</option> 
52 </select> 

53 <hd> 

54 </tr> 

55 <tr> 

56 <td colspan="2"> 

57 <center><input type=submit value=" 下 一 步 "></center> 
58 «Ad» 

59 </tr> 

60 </form> 

61 </table> 

62 </center> 

63 </body> 

64 </html> 

65 <?php 

66 } 

67 else if(!$ POST[r][1]) /没有 选择 项 参数 为 第 二 步 
68 { 

69 ?> 

70 «html» 

71 <head> 

72 ”<title> 投 票 程序 一 一 增加 投票 项 第 二 步 </title> 

73 </head> 


74 
75 
76 
TI 
78 
79 
80 
81 
82 
83 
84 
85 
86 
87 
88 
89 
90 
91 
92 
93 
94 
95 
96 
97 
98 
99 
100 
101 
102 
103 
104 
105 
106 
107 
108 
109 
110 
111 
112 
113 
114 
115 
116 
MT 
118 
119 
120 
121 
122 
123 
124 
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<body> 

<script language=javascript> 
function juge(form) 

í 


if (form.v name.value == "" 


alert "请 输入 投票 项 名 称 !); 
theForm.v name.focus(); 
return (false); 
H 

H 

</script> 

<center> 

<h1> 投 票 程序 一 一 增加 投票 项 第 二 步 </h1> 

<p> 

<h3> 投 票 项 每 项 选择 项 属性 </h3> 

<p> 

<table border=1> 
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«form method="post" action=<?php echo $PATH INFO;?» onsubmit="return juge(this)"» 


«?php 
$v name-$ POST[v name]; // 获 取 传 入 变量 
$v type-$ POST[v _type'; 
$v m-$ POST[v mj; 
echo "<tr><td colspan-4»«center2".$v name."«/center»«/td»«/tr»n"; 
echo "<input type=hidden namez-v name valuez-".$v name."»n"; 
echo "<input type=hidden name-v type value-".$v type."»n"; 
echo "<input type=hidden namezv m value-".$v m."»n"; 


for($i=1;$i<($v_m+1);$i++) /| 循环 显示 每 个 选择 项 


t 
echo "«tr»"; 
echo "<td> 选 择 项 ".$i." 内 容 : </td>\n"; 
echo "<td>"; 
echo "<input type-text name=r[]>"; 
echo "</td>\n"; 
echo "<td>"; 
echo "颜色 "; 
echo "</td>\n"; 
echo "<td>\n"; 
echo "<select size=1 name=c[]>\n"; 
echo "<option value=1> 红 </option>\n"; 
echo "<option value=2> 蓝 </option>\n"; 
echo "<option value=3> 绿 </option>\n"; 
echo "<option value=4> 黄 </option>\n"; 
echo "<option value=5> 紫 </option>\n"; 
echo "</td>\n"; 
echo "</tr>\n"; 


?> 

<tr> 

<td colspan="4"> 
<center> 
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125 
126 
127 
128 
129 
130 
131 
132 
133 
134 
135 
136 
137 
138 
139 
140 
141 
142 
143 
144 
145 
146 
147 
148 
149 
150 
151 
152 
153 
154 
155 
156 
157 
158 
159 
160 
161 
162 
163 
164 
165 
166 
167 
168 
169 
170 
171 
172 
173 
174 


@ 


<input type=button value=" E— 3" onclick=history.go(-1)> 
<input type=submit value=" F— 4"> 
</center> 
</td> 
«itr» 
</form> 
</table> 
</center> 
</body> 
</html> 
<?php 
H 
else // 除 以 上 两 种 情况 之 外 为 第 三 步 
{ 
$v name-$ POST[v name]; // 获 取 传 入 变量 
$v type-$ POST[Vv type]; 
$v m-$ POST[v mj; 
for($i=0;$i<$v_m;$i++) /| 循环 读 取 数 组 变量 
ii 
$r0-$ POSTITIISi; 
$c[]Á-$ POST[cISi]; 
) 
require "17-1.php"; 
$linkezmysql connect($db host,$db user,$db pass); 
mysql select db($db name,Slink); /| 连接 服务 器 选择 库 
$sql="insert into $table vote(v name,v type) values($v name'/$v type")"; 
mysql_query($sql, $link); /| 插入 投票 记录 
$sql="select max(id) from $table vote"; 
$result-mysql query($sql,Slink ); 
$row-mysql fetch array($result); 
for($i=0;$i<$v_m;$i++) // 循 环 插 入 选择 项 记录 
{ 
Stemp-$r[Si]; 
S$temp2-$c[Si]; 
$sql-"insert into $table record(r id,r name,r color) values('$row[0]''Stemp', $temp2")"; 
mysql! query($sql,Slink); /插入 记录 


?> 
<html> 
<head> 
<meta http-equiv="refresh" content="2; url=17-3.php"> 
<title> 投 票 程序 一 一 增加 投票 项 第 三 步 </title> 
</head> 
<body> 
投票 项 创建 成 功 ! <p> 
两 秒 后 返回 
</body> 
<?php 
H 


?> 
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17.4.4 创建 删除 投票 项 的 页 面 
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本 小 节 来 创建 删除 投票 项 的 页 面 。 该 文件 首先 要 获取 用 户 提交 的 ID， 然 后 从 表 中 选择 相应 的 ID 
并 进行 删除 操作 。 删 除 投票 的 实质 是 要 对 两 个 表 进 行 操作 。 首 先 要 删除 表 vote 中 指定 ID 的 记录 ， 接 
着 要 删除 表 record 中 R_ID 等 于 指定 ID 的 记录 ， 也 就 是 删除 投票 项 相应 的 选择 项 。 

【实例 17-5】 以 下 代码 为 创建 删除 投票 项 的 页 面 。 


实例 17-5. 删除 投票 项 的 页 面 
源码 路 径 ， 光盘 \ 源 文件 \17\17-5.php 


01 <?php 

02 ifl GET[id']) // 如 果 没 有 指定 删除 ID ， 显 示 信 息 
03 

04 echo "没有 指定 ID! "; 

05 exit(); 

06 ) 

07 else /如 果 指定 了 删除 ID， 执行 操作 
08 { 

09 require "17-1.php"; // 调 用 配置 文件 

10 $link-mysg! connect($db host,$db user,$db pass)or die(mysql error()); // 连 接 主机 
11 mysq| select db($db name,Slink); /选择 数据 库 

12 $sql="delete from $table vote where id-'$ GET[id]"; /删除 指定 投票 项 

13 if(mysql query(S$sql,Slink)); /发 送 SQL 请 求 并 对 结果 进行 判断 
14 { 

15 echo "成 功 删除 投票 项 !"; 

16 } 

Vf else 

18 ( 

19 echo "删除 投票 项 时 出 现 错误 ! "S 

20 ) 

21 echo "<p>"; 

22 $sql2-"delete from $table record where r id='$_GET[id]j"// 删 除 指定 选择 项 ， 即 某 个 投票 项 的 所 有 选 
择 支 

23 if(mysql_query($sql2,$link)); /发 送 SQL 请 求 并 判断 结果 

24 { 

25 echo "成 功 删除 选择 项 ! "s 

26 ) 

27 else 

28 ( 

29 echo "删除 选择 项 时 出 现 错误 ! "; 

30 ) 

31 echo "<html>"; 

32 echo "<head>"; 

33 echo "<title> 投 票 程序 一 一 删除 投票 项 </title>"; 

34 echo "<meta http-equiv=\"refresh\" contentzV2; url=17-3.php\">"; 

35 echo "</head>"; 

36 echo "<body>"; 


(0 PHP 网 络 编程 技术 详解 


37 
38 
39 
40 
41 


echo "成 功 删 除 投票 项 记录 !"; 
echo "<p>"; 

echo "两 秒 后 返回 "; 

echo "</body>"; 


注意 : 本 实例 中 应 该 注意 SQL 语句 的 准确 性 。 


17.4.5 创建 显示 投票 项 页 面 
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本 小 节 来 编写 投票 项 的 显示 页 面 。 注 意 本 节 与 17.4.2 小 节 的 不 同 。 本 小 节 是 显 7 


细 情 况 ， 即 每 一 个 投票 项 和 它 所 包括 的 选择 项 。 


这 里 采用 两 种 方式 来 显示 , 一 种 是 采用 通常 的 页 面 方式 显示 ; 另 一 种 是 采用 JavaScript 方式 来 显示 。 


为 什么 这 样 呢 ? 因为 通常 网 上 的 普通 空间 并 不 支持 PHP, 而 采用 JavaScript 方式 显示 , 只 需 提供 相应 的 
JS 代码 就 可 以 实现 投票 功能 。 如 果 采 用 普通 的 显示 方式 ， 则 是 提供 给 支持 PHP 代码 的 用 户 ， 因 为 这 些 
用 户 完全 可 以 直接 拿 来 使 用 。 
【实例 17-6】 以 下 代码 为 创建 显示 某 一 条 投票 项 的 页 面 。 
re 实例 17-6: 创建 显示 某 一 条 投票 项 的 页 面 

o-—9 . 源码 路 径 。 光盘 \ 源 文件 \1\17-6.php 

01 <?php 

02 if(I$ GET[id']) // 如 果 没 有 指定 ID 号 

03 

04 echo "没有 指定 ID! "; 

05 exit(); 

06 H 

07 else 

08 { 

09 echo "«html»"; 

10 echo "<head>"; 

11 echo "<title> 投 票 程序 一 一 显示 投票 项 </title>"; 

12 echo "</head>"; 

13 echo "<body>"; 

14 echo "<center>"; 

15 require "17-1.php"; // 调 用 配置 文件 

16 $link=mysql_connect($db_host$db user,$db pass)or die(mysql_error()); 

17 mysql select db($db name,Slink); /选择 数据 库 

18 $sql="select * from Stable vote where id-'$ GET[id"; — // 旺 示 指 定投 票 项 

19 $result=mysql_query($sql,$link); /发 送 SQL 请 求 

20 $row=mysql_fetch_array($result); /计算 总 列 数 

21 $s=$row[v_num']; /赋值 给 变量 

22 echo "<h1>$row[v_name]</h1>"; /显示 投票 项 标题 

23 echo "«p»"; 

24 echo "<table border=\"1\" width=60%>"; 

25 echo "<form action=17-9.php method=post>"; 
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26 echo "<input type=hidden name=id value=". $row['id].">"; 

27 echo "<input type=hidden name-v type value-".$row[v type]."»"; 

28 echo "<tr>"; 

29 echo "<td>&nbsp;</td><td> 选 项 </td><td> 被 选择 情况 </td>"; 

30 echo "</tr>"; 

31 $sql2-"select * from $table record wherer id-$ GET[id]"; 

32 $result22mysql query($sql2,Slink); /发 送 SQL 请 求 以 显示 选择 项 
33 while($rows-mysgl fetch array($result2)) 

34 { 

35 echo "<tr>"; 

36 echo "<td>"; 

37 if($row[v. type']--0) Ua PE SER RAA 

38 ( 

39 echo "<input type=radio name=r value=".$rows['id].">"; 

40 ) 

41 else /如 果 选 择 类 型 是 多 选 

42 { 

43 echo "<input type=checkbox name= 中 value=".$rowsf'id].">"; 

44 y 

45 echo "</td>"; 

46 echo "<td>".$rows['r_name']."</td>"; 

47 echo "<td>"; 

48 if($rows[r num']--0) /如 果 被 投票 数 为 0 

49 $width=0; /图 片 宽度 为 0 

50 else 

51 $width=$rows[r_num']/$s; /图 片 宽度 为 得 票数 除 以 总 投票 数 
52 if(Swidth!-0) /如果 被 投票 数 不 为 0， 显示 图 片 
53 { 

54 echo "<img src-".$rows[r color].".bmp width=".($width*200)." height=10>\n"; 
55 } 

56 echo $rows[r num']."/".Srow[v num]; /显示 数字 

57 echo "</td>"; 

58 echo "</tr>"; 

59 ) 

60 echo "<tr><td colspan-3»«center»«input type=submit value-V f 1 38 37 V» «/center» «/td» «/tr»"; 
61 echo "</form>"; 

62 echo "</table>"; 

63 ) 

64 ?> 


说 明 : 本 实例 的 核心 就 是 判断 并 遍历 输出 操作 。 
【实例 17-7】 以 下 代码 为 调用 JS 显示 相应 内 容 的 PHP 文件 。 


实例 17-7: 调用 JS 显示 相应 内 容 的 PHP 文件 
源码 路 径 : 光盘 '\ 源 文件 \17\17-7.php 


01  documentwrite("«?php require '17-1.php'; 


02 $linkzmysql connect($db host,$db user,$db pass); 
03 mysql select db($db name.Slink); 
04 $sql-"select * from $table vote where id-$ GET[id]"; 
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05 $result=mysql_query($sql,$link)or die(mysql error()); 

06 $row-mysql fetch array(Sresult); 

07 $s-$row[v num; 

08 echo "<center>"; 

09 echo '«h12'.$row[ v name7.'«/h1»*; 

10 echo "<p>"; 

11 echo '«table border-1 width=60%>'; 

12 echo '«form actionz17-9.php method-post^'; 

13 echo "<input type=hidden namecid value=". $row['id].>"; 

14 echo '«input type=hidden namezv type valuez'.$row[v type7.'»*; 
15 echo '<tr>'; 

16 echo '<td>&nbsp;</td><td> 选 项 </td><td> 被 选择 情况 </td>'; 

17 echo '</tr>'; 

18 $sql2-"select * from $table record wherer id-$ GET[id]"; 

19 Sresult2=mysql_query($sql2, $link)or die(mysql error()); 

20 while($rows-mysql fetch array($result2)) 

21 ( 

22 echo '«tr?'; 

23 echo '<td>'; 

24 if($row[v. type']--0) 

25 i 

26 echo '<input type=radio name=r value-'.$rows[id'].'»"; 
27 ) 

28 else 

29 ( 

30 echo '«input typezcheckbox namezr[] valuez'.$rows['id'].'; 
31 ) 

32 echo '«/td»"; 

33 echo '«td»'.$rows['r name7.'«/td»"; 

34 echo '«td»«br />'; 

35 if(Srows[r num]--0) 

36 $width=0; 

37 else 

38 $width-$rows[r num"/$s; 

39 if($width!=0) 

40 { 

41 echo '<img src=".$rows['r_color].'.bmp width=".($width*200).' height=10>'; 
42 } 

43 echo $rows['r num']./.$row[v num?; 

44 echo '</td>'; 

45 echo '</tr>'; 

46 ) 

47 echo '«tr»«td colspan-3»«center»«input type=submit value= 确 认 提 交 ></center></td></tr>'; 
48 echo '«/form?"; 

49 echo '</table>'; 

50 echo '«/center?"; 

51 ?> 

52 "y 


【实例 17-8】 以 下 代码 是 调用 该 JS 页 的 普通 HTML 页 面 。 


@ 
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W* “实例 17-8: 调用 实例 17-7 的 普通 HTML 页 面 
源码 路 径 光盘 \ 源 文件 17\17-8.php 


02 <head> 

03 «title» 3 S JS 页 </title> 

04 </head> 

05 «body» 

06 «script language-javascript srcz"17-7.php?id-1"» 
07 </script> 

08 </body> 

09 </html> 


由 于 该 页 面 中 没有 任何 可 执行 的 PHP 代码 , 所 以 该 页 面 可 以 是 普通 的 HTML 页 。 通 过 以 上 代码 可 
调用 JS 页 时 要 使 用 以 下 样式 : 
«script language-javascript src="17-7.php?id=1"> 
</script> 
其 中 的 sre 为 17-7.php 的 相对 或 者 绝对 路 径 ， 同 时 也 不 能 省 略 id 值 。 这 样 就 可 以 在 不 支持 PHP 的 
网 站 上 调用 该 投票 程序 了 。 当 然 ， 如 果 是 提供 给 普通 用 户 使 用 ， 其 中 的 sre 就 一 定 要 为 绝对 路 径 ， 因 为 
用 户 的 文件 等 不 可 能 和 服务 器 上 的 程序 在 一 个 路 径 之 下 。 

另外 ， 单 独 使 用 这 样 的 调用 即 显示 投票 情况 ， 是 会 成 功 的 。 但 要 处 理 这 样 的 提交 结果 ， 就 一 定 要 
把 下 面 要 讲 到 的 提交 处 理 页 面 〈 实 例 17-9) 中 最 后 回 退 的 页 面 改 为 用 户 的 页 面 ， 这 就 需要 程序 在 处 理 
时 使 用 系统 变量 $_SERVER['HTTP_REFERER'] 记 录用 户 上 一 页 的 内 容 ， 然 后 在 处 理 结束 后 ， 重 新 返回 
用 户 的 页 面 。 


17.4.6 创建 选择 项 提交 处 理 页 面 


CH 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 17 章 \ 创 建 选择 项 提交 处 理 页 面 .wmv 

本 节 来 编写 对 选择 项 的 提交 进行 处 理 的 页 面 ， 该 页 面 实现 的 功能 是 依照 用 户 选择 的 项 目 ， 更 新 相 
应 的 记录 的 数值 。 

【实例 17-9】 以 下 代码 为 创建 选项 提交 处 理 页 面 。 


re 实例 17-9. 创建 选项 提交 处 理 页 面 
源码 路 径 ， 光 盘 \ 源 文件 \17\17-9.php 


E 


01 <?php 

02 Sid-$ POST[id; /获取 用 户 提交 的 ID 值 
03 $v_type=$_POST[v_type]; /获取 投票 项 的 类 型 
04 $r=$_POST[r]; /获取 投票 项 内 容 

05 require "17-1.php"; 

06 $linkzmysql connect($db host,$db user,$db pass); 

07 mysql! select db($db name,Slink); 

08 if($v type--0) // 如 果 投票 类 型 是 单 选 
09 { 

10 $sql="update $table vote set v numzv num*1 where id=$id"; /更 新 投票 记录 +1 


KI 


PH 
PH 


35 
36 ?> 
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mysql_query($sql,$link); 
$sql2-"update $table record setr num=r_num+1 whereid-$r" /更 新 选择 支 记录 +1 
mysql_ query($sql2,$link); 

) 


else /如 果 投票 项 是 多 选 
for($i=0;$i<count($r);$i++) // 通 过 循环 实现 记录 的 更 新 
{ 
$sql="update $table vote set v_num=v_num+1 where id=$id"; 
mysql_query($sql,$link); 
$temp=$r{$i]; 
$sql2="update $table record set r_num=r_num+1 where id-$temp"; 
mysql query($sql2, $link); 
} 
} 
echo "<html>"; /处 理 结束 显示 HTML AR 
echo "<head>"; 
echo "<title> 投 票 程序 一 一 处 理 投票 结果 </title>"; 


echo "<meta http-equiv=\"refresh\" content=\"2; url=17-6.php?id=$id\">"，// 返 回 17-6.php 
echo "</head>"; 

echo "<body>"; 

echo "投票 成 功 !"; 

echo "<p>"; 

echo "两 秒 后 返回 "; 

echo "</body>"; 


WBA: 本 实例 的 核心 就 是 获取 选择 项 并 更 新 数据 库 中 相应 的 数据 。 
至 此 ， 该 投票 程序 的 全 部 主要 功能 已 经 编写 完毕 。17.5 节 开 始 对 所 有 功能 进行 调试 。 


17.5 测试 程序 


EB 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 17 章 \ 测 试 程序 .wmv 

程序 测试 是 程序 编写 后 一 个 重要 的 环节 ， 程 序 在 编写 完成 后 都 要 进行 测试 。 通 过 对 代码 的 测试 可 
以 发 现 其 中 的 BUG， 然 后 就 可 以 排除 BUG， 使 程序 更 好 地 运行 。 

由 于 配置 文件 、 创 建 表 的 准备 工作 在 17.4.1 节 中 已 经 完成 ， 本 节 就 直接 从 显示 投票 项 开始 。 所 以 ， 
第 一 步 ， 在 PHP 运行 环境 中 执行 实例 17-3， 将 显示 如 图 17.2 所 示 的 执行 结果 。 
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图 17.2 第 一 次 运行 显示 投票 项 页 面 时 的 执行 结果 
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虽然 已 经 创建 了 相应 的 表 , 但 是 表 中 并 没有 任何 记录 , 所 以 图 17.2 显示 还 没有 记录 。 这 时 单 击 “ 添 

加 记录 ” 超 链 接 来 添加 投票 记录 ， 即 执行 实例 17-4。 其 执行 结果 如 图 17.3 所 示 。 
[E5977] 
Qo -— eR 
投票 程序 一 一 增加 投票 项 第 一 步 


投票 项 属性 


$1006 ~ 
173 ”增加 投票 项 第 一 步 执行 结果 
由 于 实例 17-4 把 增加 投票 项 的 三 步 操作 化 为 了 一 步 ， 所 以 第 一 步 执行 时 ,将 会 发 现 图 17.3 所 示 的 
提示 开始 按 需 要 创建 新 的 投票 项 。 这 里 投票 项 的 内 容 定 为 : 你 对 本 站 印象 如 何 、 投 票 项 的 类 型 选择 单 
选项 和 投票 项 的 项 数 选 择 3 项 。 然 后 单 击 “ 下 一 步 ” 按 钮 ， 就 会 转 到 增加 投票 项 的 第 二 步 。 第 二 步 的 
执行 结果 如 图 17.4 所 示 。 
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图 17.4 增加 投票 项 第 二 步 执行 结果 


由 于 在 上 一 步 选 择 了 3 个 选择 项 ， 所 以 这 一 步 就 是 确定 每 个 选择 项 的 内 容 。 这 里 分 别 输入 “好 极 
了 ”、“ 很 一 般 ”、“ 糟 透 了 ”3 项 内 容 ， 颜 色 分 别 选用 红 、 黄 、 蓝 3 种 颜色 。 按 照 要 求 填写 完整 相应 
项 目 后， 再 单 击 “ 下 一 步 ” 按 钮 ， 就 转 到 了 增加 投票 项 的 第 三 步 。 由 于 第 三 步 的 操作 是 把 相应 记录 添 
加 到 表 中 , 所 以 执行 都 是 在 后 台 运 行 。 并 且 执行 完毕 后 , 直接 跳 转 到 显示 所 有 投票 项 页 面 , 即 实例 17-3. 
跳 转 后 的 结果 如 图 17.5 所 示 。 


说 明 : 当然 ， 这 里 读者 可 以 添加 自己 喜欢 的 条 目 。 

通过 图 17.5 的 执行 结果 可 以 发 现 , 已 经 正常 显示 出 了 前 面 添加 过 的 投票 项 “你 对 本 站 印象 如 何 ”， 
说 明 程 序 正 常 运行 。 单 击 投票 项 名 称 超 链 接 ， 将 会 转 到 显示 投票 项 的 页 面 ， 即 相当 于 执行 实例 17-6。 
执行 结果 如 图 17.6 所 示 。 

从 图 17.6 了 解 到 ， 投 票 程序 正确 地 显示 了 投票 项 及 其 选择 项 的 内 容 。 由 于 此 时 并 没有 任何 投票 ， 
或 者 说 没有 做 任何 的 选择 ， 所 以 每 一 个 选择 项 的 选择 次 数 都 是 0 次。 下 面 尝试 选择 图 17.6 中 的 “好 极 
了 ”， 然 后 单 击 “ 确 认 提交 ”按钮 。 由 于 该 页 表单 的 action 属性 指向 17-9.php， 所 以 将 会 调用 17-9.php 
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图 17.5 添加 完投 票 项 后 的 显示 投票 项 页 面 执行 结果 图 17.6 显示 投票 项 详细 信息 页 面 执行 结果 
像 上 面 添加 记录 一 样 ， 处 理 页 面 更 新 表 中 的 内 容 ， 即 把 vote 表 中 的 v. num 增加 1， 再 把 record 表 中 


的 相应 项 的 r_num 增加 1。 处 理 完成 后 ， 将 返回 显示 投票 项 详细 信息 的 页 面 。 处 理 结果 如 图 17.7 所 示 。 
每 一 项 投票 结果 都 被 正确 地 显示 了 出 来 ， 说 明 该 程序 正确 处 理 了 用 户 提交 的 投票 结果 。 
下 一 步 来 测试 一 下 多 项 选择 是 否 能 正确 执行 。 先 运行 实例 17-4 创建 一 个 多 项 投票 项 , 如 标题 为 “你 
觉得 本 站 还 应 增加 哪些 内 容 ?”， 选 择 项 为 游戏 、 动 漫 、 软 件 、 硬 件 、 小 说 、 玄 幻 、 体 育 等 。 把 每 一 
项 都 设 定好 相应 的 颜色 ， 创 建 后 的 显示 信息 如 图 17.8 Bras 
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图 17.7 显示 投票 项 的 投票 结果 图 17.8 显示 多 选 投票 项 详细 情况 


下 面 分 别 一 次 选择 其 中 的 多 项 内 容 以 测试 多 选项 是 否 成 功 执行 ， 执 行 结果 如 图 17.9 所 示 。 

如 图 17.9 所 示 ， 如 果 用 户 一 次 选择 4 项 ， 就 会 当 作 单 选 的 4 次 的 投票 被 计 入 库 中 ， 而 每 被 投 中 的 
一 次 将 会 作为 一 次 投票 。 经 测试 达到 了 正确 处 理 多 项 选择 的 目的 : 把 一 次 多 选 的 几 项 当 作 几 次 计数 ， 
如 一 次 多 选 了 多 项 内 容 ， 就 当 作 多 次 计数 。 

重新 回 到 实例 17-3 的 执行 页 面 。 因 为 接 下 来 要 测试 删除 投票 项 的 功能 。 在 执行 删除 操作 之 前 ， 共 
有 两 条 投票 项 《〈 即 测试 时 添加 的 两 条 ) ， 如 图 17.10 所 示 。 

这 时 单 击 其 中 一 条 后 面 对 应 的 “删除 ” 超 链接 ， 将 会 执行 17-9.php。 该 页 面 的 功能 就 是 把 参数 ID 
所 对 应 的 投票 项 及 其 在 record 表 中 的 所 有 选择 项 全 部 删除 。 在 执行 完全 部 操作 后 ， 又 会 自动 跳 回 到 
17-3.php。 所 以 只 有 通过 操作 前 后 的 对 比 才 能 发 现 程序 是 否 正 确 执行 ， 结 果 如 图 17.11 所 示 。 

通过 图 17.10 与 图 17.11 的 对 比 可 以 发 现 第 2 条 记录 不 见 了 ， 实 际 上 它 已 经 被 成 功 删除 。 

测试 完 以 上 功能 后 ， 来 测试 JS 调用 页 面 的 功能 。 要 测试 这 项 功能 直接 在 浏览 器 地 址 栏 中 执行 
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17-8.php 即 可 ， 执 行 结 果 如 图 17.12 所 示 。 
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图 17.11 删除 后 的 所 有 投票 项 图 17.12 ”使 用 JS 调用 页 面 的 执行 结果 


由 图 17.12 可 以 发 现 ， 通 过 JS 调用 ， 显 示 出 了 与 直接 使 用 显示 投票 项 页 面 几乎 完全 一 致 的 内 容 。 
说 明 该 功能 也 使 用 正常 。 需 要 注意 的 是 ， 当 用 户 使 用 JS 调用 的 页 面 提交 时 ， 必 须要 把 实例 17-9 处 理 
操作 结束 后 所 要 回转 的 页 面 地 址 做 一 下 改动 ， 使 用 系统 变量 $_ SERVER['"HTTP_REFERER'] 重 新 返回 用 
户 的 页 面 。 


17.6 ”如 何 防止 重复 投票 


FÈ 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 17 章 \ 如 何 防止 重复 投票 .wmv 

投票 程序 应 该 具有 的 功能 已 经 比较 完善 了 ， 但 还 是 不 能 限制 用 户 重复 投票 。 这 里 只 给 出 一 个 思路 ， 
由 于 实现 起 来 相当 简单 ， 有 兴趣 的 读者 可 以 自己 通过 实践 来 解决 。 

在 实例 17-1 中 有 一 个 $re_vote (重复 投票 ) 变量 。 读 者 可 以 在 执行 实例 17-9 处 理 用 户 提 交 操 作 之 
前 先 来 判断 该 值 , 如 果 该 值 设 定 为 True,， 即 允许 用 户 重复 投票 , 则 不 执行 任何 操作 ; 如 果 该 值 为 False， 
则 先 判断 有 无 某 个 Cookie 值 ， 如 果 没 有 ， 把 用 户 IP 写 入 某 个 Cookie 值 (如何 获 得 用 户 IP， 请 参阅 第 9 
章 的 内 容 ) 。 如 果 存 在 该 Cookie 值 ， 则 把 用 户 的 IP 与 该 值 相 比 较 ， 如 果 二 者 不 一 致 就 继续 执行 下 面 的 


Ò 


M aaa 


操作 ， 如 果 二 者 一 致 就 给 出 不 允许 重复 投票 的 提示 ， 并 且 使 用 exit() 函 数 中止 所 有 PHP 语句 的 执行 。 
说 明 : 这 是 一 种 简单 有 效 的 防止 重复 投票 的 方法 。 


这 样 一 来 就 可 以 有 效 防止 用 户 重复 投票 ， 既 增加 了 投票 结果 的 真实 性 、 可 信 度 ， 又 可 以 减轻 服务 
器 的 负担 。 


17.7 本 章 小 结 


本 章 和 读者 一 起 完成 了 一 个 网 上 投票 程序 。 通 过 本 章 的 学 习 ， 一 方面 复习 了 数据 库 的 知识 ， 另 一 
方面 也 使 读者 了 解 到 如 何 采用 不 同 的 方法 来 解决 相同 的 问题 ， 进 一 步 增强 了 读者 使 用 PHP 来 处 理 实际 
问题 的 能 力 。 但 是 本 章 所 介绍 的 投票 程序 实例 毕竟 是 十 分 简单 的 ， 实 际 应 用 时 投票 程序 往往 需要 有 多 
方面 的 要 求 。 不 管 它们 的 功能 有 多 少 ， 内 容 多 么 复杂 ， 其 最 核心 的 内 容 还 是 对 数据 表 的 操作 。 相 信 各 
位 读者 通过 本 章 的 学 习 ， 加 上 自己 的 思考 与 努力 ， 一 定 能 写 出 高 效 、 简 洁 的 网 上 投票 程序 。 


第 18 章 义 本 留言 板 程 序 


留言 板 在 网 络 上 有 着 极为 广泛 的 应 用 , 它 是 沟通 网 站 管理 人 员 与 普通 浏览 者 的 一 个 强 有 力 的 纽带 。 
不 论 是 个 人 的 小 型 网 站 ， 还 是 企业 的 大 型 站 点 ， 都 可 以 发 现 留 言 板 的 影子 。 如 果 一 个 网 站 中 没有 留言 
板 ， 那 就 无 法 和 普通 浏览 的 用 户 进行 有 效 的 沟通 。 既 然 留 言 板 有 如 此 广泛 的 应 用 ， 那 么 编写 留言 板 就 
成 了 编写 大 型 Web 应 用 程序 的 基础 。 

本 章 介绍 如 何 编写 一 个 文本 型 的 留言 板 ， 包 括 留言 板 分 类 、 文 本 留言 板 的 实现 原理 、 文 本 留言 板 
实例 的 构成 、 文 本 留言 板 配 置 文件 的 建立 、 编 写 显示 留言 及 提交 留言 页 、 后 台 修改 留言 功能 的 实现 、 
后 台 删 除 留言 功能 的 实现 以 及 进一步 完善 等 内 容 。 通 过 本 章 的 学 习 ， 读 者 能 掌握 编写 PHP 文本 留言 
的 技能 。 


18.1 留言 板 分 类 


留言 板 是 网 络 上 使 用 最 广 的 互动 Web 应 用 程序 之 一 。 由 于 其 使 用 灵活 、 方 法 简单 、 用 户 与 管理 者 
之 间 互 动 效果 明显 ， 所 以 一 直 深 受 网 络 管理 者 与 使 用 者 的 欢迎 。 网 上 常见 的 留言 板 按照 它们 存储 机 制 
的 不 同 大 致 可 以 分 为 以 下 两 大 类 : 文本 留言 板 和 数据 库 留言 板 ， 本 节 将 为 读者 分 别 作 介 绍 。 


18.1.1 文本 型 留言 板 


GE 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 18 章 \ 文 本 型 留言 板 .wmv 
所 谓 文本 留言 板 ， 就 是 采用 文本 文件 作为 数据 存储 方式 的 一 类 留言 板 。 文 本 留言 板 由 于 采用 文本 
文件 作为 数据 存储 的 载体 ， 所 以 与 其 他 类 型 的 留言 板 相 比较 ， 具 有 以 下 几 个 特征 : 

由 于 不 需要 数据 库 支 持 ， 所 以 文本 留言 板 只 要 服务 提供 商 支持 普通 PHP 程序 就 可 以 使 用 。 

与 其 他 类 型 留言 板 程序 相 比 ， 可 移植 性 强 。 数 据 备份 也 更 为 简单 ， 只 需要 将 相应 数据 文件 备 
份 即 可 。 

文本 留言 板 在 处 理 内 容 比较 少 的 数据 时 往往 速度 比较 快 ， 但 是 在 处 理 大 量 数据 ， 如 留言 数据 
达到 千 万 的 数量 级 时 就 会 显得 力不从心 。 


A ”由 于 没有 专门 的 函数 ， 所 以 与 数据 库 留 言 本 相 比 ， 插 入 、 修 改 、 删 除 记录 操作 起 来 相对 要 有 麻 
烦 一 些 。 

回 ”由 于 文本 留言 板 的 数据 采用 纯 文 本 的 方式 进行 排列 ， 所 以 记录 检索 起 来 也 不 如 数据 库 留言 板 
那么 方便 。 


以 上 列 出 了 文本 留言 板 的 几 个 特点 ， 可 见 与 其 他 类 型 的 留言 板 相 比 ， 文 本 留言 板 有 一 定 不 足 ， 但 
它 的 优点 也 是 相当 明显 的 。 所 以 ,文本 留言 板 在 网 络 上 有 相当 多 的 拥护 者 。 这 也 是 本 章 所 要 介绍 的 
重点 。 
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18.1.2 ”数据 库 型 留言 板 


GE 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 18 章 \ 数 据 库 型 留言 板 .wmv 

文本 留言 板 固然 有 很 多 优点 ， 但 不 足 之 处 也 是 显而易见 的 。 如 不 具备 搜索 功能 ; 插入、 修改 、 删 
除 留言 相对 比较 麻烦 等 。 这 些 不 足 ， 在 数据 库 留 言 板 中 就 变 得 非常 轻松 。 由 于 数据 库 留 言 板 采 用 数据 
库 作 为 数据 载体 ， 所 以 插入 、 修 改 、 删 除 留言 时 只 需 执 行 相应 的 SQL 语句 即 可 ， 而 留言 搜索 更 是 可 以 
轻松 实现 。 下 面 来 了 解 一 下 数据 库 留 言 板 的 特点 : 

回 数据库 留言 板 是 以 数据 库 、 数 据 表 作 为 留言 数据 存储 载体 的 一 类 留言 板 程序 的 统称 。 由 于 用 
数据 库 作 为 数据 载体 ， 相 对 于 文本 留言 板 来 说 ， 它 的 优点 非常 明显 。 但 与 之 相 比 ， 缺 点 也 是 
显而易见 的 。 

Ep ”由 于 使 用 数据 库 作 为 载体 ， 所 以 在 处 理 留 言 信息 时 速度 很 快 ， 特 别 是 在 处 理 大 量 数据 时 ， 速 
度 优势 更 为 明显 。 

回 有 PHP 数据 库 函数 库 的 支持 ， 依 托 高 效 SQL 的 语句 ， 数 据 库 留言 板 实现 数据 插入 、 修 改 、 删 
除 都 非常 方便 快捷 。 

回 言 记录 搜索 功能 对 于 数据 库 留言 板 来 说 更 是 小 菜 一 碟 ， 甚 至 它 还 支持 任何 字段 的 模糊 查找 。 

B ”由 于 需要 数据 库 支 持 ， 所 以 对 服务 提供 商 要 求 较 多 。 一 旦 服务 供应 商 不 支持 这 项 服务 ， 那 么 
这 种 类 型 的 留言 板 将 无 法 运行 。 

Ep ”可 移植 性 与 文本 留言 板 比较 起 来 较 差 。 在 一 个 空间 运行 正常 的 程序 到 了 另 一 个 地 方 ， 就 要 修 

改 相关 配置 选项 ， 而 文本 留言 板 几乎 可 以 不 做 任何 修改 就 可 以 在 不 同 的 空间 上 正常 运行 。 

相对 文本 留言 板 来 说 ， 数 据 备份 相对 麻烦 。 虽 然 有 高 效 的 数据 库 管理 程序 如 phpMyAdmin 之 

类 的 可 以 轻松 实现 数据 库 的 导出 导入 ， 但 相对 于 只 用 使 用 复制 、 粘 贴 就 可 以 轻松 备份 的 文本 

留言 板 来 说 还 是 显得 有 些 麻 烦 。 

说 明 : 以 上 列 出 了 数据 库 留 言 板 的 一 些 特 点 。 通 过 对 比 可 以 发 现 ， 两 种 留言 板 互 有 长 短 ， 互 为 补充 ， 
不 能 说 哪 种 更 好 。 


如 果 是 个 人 用 户 ， 推 荐 使 用 文本 留言 板 ， 因 为 该 种 类 型 留言 本 小 巧 玲 珑 ， 管 理 方便 。 在 留言 数量 
相对 少 的 情况 下 使 用 者 能 体会 到 文本 留言 板 的 快捷 与 便利 。 如 果 是 企业 级 的 用 户 ， 还 是 推荐 使 用 数据 
库 留 言 板 。 对 于 企业 服务 器 来 说 ， 数 据 库 支 持 不 是 问题 。 另 外 ， 企 业 也 不 可 能 经 常 更 换 服 务 器 或 者 空 
间 ， 可 移植 性 与 数据 备份 的 麻烦 可 以 忽略 不 计 。 最 主要 的 是 ， 使 用 数据 库 留言 板 ， 可 以 使 用 数据 库 的 
强大 功能 ， 并 且 数 据 存储 量 可 以 不 受 限 制 。 

留言 板 的 类 型 就 介绍 到 这 里 ， 从 18.2 节 开始 就 来 为 读者 介绍 如 何 具 体 实现 PHP 文本 留言 板 。 
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18.2 文本 留言 板 的 实现 原理 


GEH 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 18 章 \ 文 本 留言 板 的 实现 原理 .wmv 
本 节 来 介绍 文本 留言 板 的 实现 原理 。 文 本 留言 板 是 把 用 户 输入 的 数据 存 入 一 个 文本 文件 。 虽 说 是 
文本 文件 ， 但 这 个 文件 的 扩展 名 不 一 定 是 kt， 它 可 以 是 任意 的 扩展 名 ， 如 php、dat、gif、mp3、jpg、 
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rm， 甚 至 可 以 不 加 任何 扩展 名 。 用 户 输 入 数据 的 存储 格式 一 般 是 一 条 记录 占用 一 行 ， 每 一 行 都 有 一 个 
行 标 ， 以 及 所 输入 的 各 项 内 容 。 各 项 内 容 之 间 使 用 特殊 符号 将 它们 分 隔 开 来 。 特 殊 符号 ， 可 以 自由 定 
义 。 但 是 为 了 区 别 于 普通 输入 内 容 , 一 般 不 采用 标准 的 字符 , 而 是 用 一 些 不 常用 的 字符 , n" ||". * 2" 
“一 ”、“###”、“$$$” 等 。 如 下 面 这 一 段 就 显示 了 一 行文 本 留言 板 的 记录 : 
15||JACKlljack@hotmail.com|| 欢 迎 大 家 来 到 这 里 并 留言 ! <br> 我 祝 大 家 心情 愉快 ， 工 作 顺 利 ! ||2013 年 5 月 5 日 
11:42||127.0.0.1 
通过 查看 上 面 的 内 容 ， 可 以 发 现 ， 该 文本 留言 板 程序 使 用 了 “||” 来 分 割 用 户 所 输入 的 各 项 内 容 。 
各 项 内 容 的 含义 大 致 如 下 所 示 : 


15 行 号 

JACK 姓名 
jackGhotmail.com 电子 信箱 
欢迎 大 家 来 …… 留言 内 容 
2013 年 5 月 5 日 11:42 留言 日 期 及 时 间 
127.0.0.1 IP 地 址 


将 留言 内 容 按 特 定格 式 存 入 文本 文件 ， 在 需要 显示 时 ， 再 按照 相应 的 格式 显示 出 来 即 可 。 

另外 一 点 就 是 文本 留言 板 的 分 页 显示 。 它 不 像 数 据 库 那样 读 取 相 应 的 记录 即 可 ， 文 本 留言 板 分 页 
的 实现 原理 是 读 取 相应 的 行 。 如 一 共有 25 条 记录 ， 共 分 25 行 。 如 果 是 第 一 页 ， 就 显示 第 25 一 16 条 记 
A; 如 果 是 第 二 页 就 显示 第 15 一 6 条 记录 ; 如 果 是 第 三 页 就 显示 第 5 一 1 条 记录 ， 以 此 类 推 。 这 样 就 可 
以 实现 多 页 的 显示 了 。 

还 有 就 是 修改 与 删除 留言 数据 ， 与 数据 库 留言 板 相 比 ， 这 也 有 点 麻烦 。 需 要 对 相应 的 记录 读 出 后 
按 要 求 进行 修改 或 者 删除 操作 。 


18.3 本章 文 本 留言 板 实例 的 组 成 


DP 知识 点 讲解 ， 光盘 \ 视 频 讲解 \ 第 18 章 \ 本 章 文本 留言 板 实例 的 组 成 -wmv 

本 节 来 介绍 文本 留言 板 实例 的 组 成 。 

将 要 讲解 到 的 文本 留言 板 程序 由 以 下 文件 组 成 : 

实例 18-1 CI8-Lphp) 是 系统 的 配置 文件 ， 里 面 放 置 几 个 重要 的 全 局 变量 。 包 括 文件 名 、 管 理 
者 密码 、 每 页 显示 的 留言 条 数 等 内 容 。 

实例 18-2 (18-2.php) 是 系统 的 最 主要 的 文件 。 该 文件 把 留言 显示 、 留 言 的 提交 前 台 、 留 言 的 
提交 后 台 处 理 三 项 功能 整合 到 一 个 文件 之 中 。 这 样 做 既 减 少 了 文件 个 数 ， 又 便于 管理 。 

实例 18-3 (18-3.php) 是 系统 管理 的 登录 页 。 通 过 该 文件 ， 管 理 者 可 以 登录 到 服务 器 后 注册 
Cookie。 然 后 就 可 以 对 留言 执行 修改 、 删 除 等 操作 。 

实例 18-4 (18-4.php) 是 系统 的 修改 留言 处 理 页 面 。 在 执行 修改 操作 前 会 先 判 断 Cookie 值 ， 
如 果 Cookie 值 与 系统 配置 文件 (18-1.php) 中 给 定 的 不 一 致 则 返回 错误 提示 ， 如 果 一 致 则 执 
行 修改 操作 。 

实例 18-5(18-5.php) 系 统 的 删除 留言 处 理 页 面 .在 执行 删除 操作 前 会 先 判断 Cookie 值 , 如 果 Cookie 
值 与 系统 配置 文件 (18-1.php》 中 给 定 的 不 一 致 则 返回 错误 提示 。 如 果 一 致 就 执行 删除 操作 。 


© 


18.4 节 就 来 实现 上 述 所 介绍 的 文件 。 
18.4 文本 留言 板 代 码 的 实现 


前 面 儿 节 讲 到 了 留言 板 的 分 类 、 文 本 留言 板 的 实现 原理 以 及 要 讲 到 的 文本 留言 板 的 构成 。 这 些 都 
是 为 本 节 要 讲 到 的 内 容 做 准备 。 本 节 就 来 逐个 实现 整个 系统 的 功能 。 


18.4.1 配置 文件 的 建立 


FH 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 18 章 \ 配 置 文件 的 建立 .wmv 

本 小 节 首 先 来 创建 文本 留言 板 系统 的 配置 文件 ， 该 文件 在 程序 运行 时 起 关键 作用 。 因 为 配置 文件 
定义 了 几 个 对 系统 运行 起 关键 作用 的 全 局 变量 ， 所 以 它 决定 了 系统 所 使 用 的 存储 数据 的 文件 名 、 管 理 
者 对 留言 进行 管理 〈 修 改 、 删 除 操作 ) 登录 时 所 使 用 的 密码 、 显 示 留 言 页 每 页 显示 的 留言 条 数 等 内 容 。 

【实例 18-1】 以 下 是 该 配置 文件 的 全 部 内 容 。 


€ 实例 18-1:; EE 
源码 路 径 ， 光 盘 \ 源 文件 \18\18-1.php 


01 <?php 

02 $file name-"data.dat"; /数据 文件 名 

03 $super pass-"super man"; /管理 员 名 称 

04 $list num-10; // 每 页 显示 留言 数 
05 ?> 


说 明 : 这 里 的 匹配 值 选 项 内 容 是 可 以 根据 情况 进行 更 改 的 。 
18.4.2 ”显示 和 提交 留言 文件 的 建立 


FA 知 识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 18 章 \ 显 示 和 提交 留言 文件 的 建立 .wmv 

本 小 节 要 来 创建 文本 留言 板 系统 的 留言 显示 代码 。 由 于 使 用 了 整合 功能 ， 所 以 该 文件 还 包含 留言 
提交 前 台 、 留 言 提交 后 台 等 功能 。 可 以 说 该 文件 是 整个 系统 中 最 为 重要 的 一 个 文件 。 如 果 不 需 要 留言 
修改 、 留 言 删除 的 功能 ， 只 要 最 简单 的 发 布 留 言 、 查 看 留言 功能 ， 那 么 只 需要 这 一 个 文件 就 已 经 够 了 。 
可 见 该 文件 在 整个 系统 中 的 重要 地 位 。 

一 般 常 见 的 显示 与 提交 留言 在 一 起 的 情况 是 : 页 面 上 半 部 分 显示 留言 , 下面 有 一 个 表单 供用 户 输入 留 
言 。 这 种 情况 很 方便 ， 但 影响 了 美观 。 这 里 要 做 的 是 使 用 JavaScript 技术 ， 把 用 户 提交 留言 的 表单 放置 到 
一 个 层 中 。 用 户 浏览 留言 时 ， 该 层 是 隐藏 的 ， 只 有 当 用 户 需要 留言 ， 并 单 击 相应 链接 时 ， 才 出 现 该 层 。 关 
于 层 的 隐藏 与 显示 属于 JavaScript 的 内 容 ， 不 在 本 书 讨论 范围 ， 有 兴趣 的 读者 可 以 参考 相关 书籍 。 

【实例 18-2】 以 下 代码 为 显示 和 提交 留言 的 代码 。 


区 实例 18-2. 显示 和 提交 留言 
源码 路 径 : 光盘 \ 源 文件 \18\18-2.php 


«?php 
error reporting(0); 
require "18-1.php"; 
ifl$ POST[name7) 
1 
T 
«html» 
«head» 
<title> 文 本 留言 板 一 一 记录 显示 页 </title> 
<script language=javascript> 
function Showhide(id,flag) 
{ 
if(flag==1) 


id.style.display="; 
} 
if(flag==0) 


id.style.display-'none'; 

) 
) 
</script> 
</head> 
<body> 
<center> 
<h1> 文 本 留言 板 一 一 记录 显示 页 </h1> 


<p> 
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/如果 没有 数据 提交 显示 记录 


«a href=# onClick="Showhide(huifu,1)"> 签 写 留言 </a>&nbsp;&nbsp;<a href=18-3.php> 管 理 入 口 </a> 


<p> 
«?php 
if(!$ GET['page"]) 
$page-1; 
else 
$page-$ GET['page']; 
if(Ifile exists(Sfile name)) 


$fp-fopen($file name,"w"); 
fclose(Sfp); 


H 

$myfile-file($file name); 

if(Smyfile[0]--"" 

echo "目前 记录 条 数 为 : 0"; 

else 

t 
$tempzexplode("||",$myfile[0]); 
echo "共有 ".$temp[0]." 条 内 容 "; 
echo "&nbsp;&nbsp;&nbsp;&nbsp;"; 
$p count-ceil(Stemp[O]/Slist num); 
echo "分 ".$p_count." 页 显示 "; 
echo "&nbsp;&nbsp;&nbsp;&nbsp;"; 
echo "当前 显示 第 ".$page." 页 "; 


// 如 果 没有 参数 page 
// 则 显示 第 一 页 内 容 


// 如 果 带 有 参数 page， 则 显示 相应 页 内 容 
// 如 果 是 第 一 次 运行 (文件 不 存在 ) 


// 创 建文 件 
// 使 用 file() 函 数 把 所 有 信息 读 入 一 个 数组 


// 如 果 文件 为 空 ， 即 没有 任何 留言 信息 
// 显 示 没有 记录 的 信息 


// 读 出 数组 第 一 条 记录 到 数组 
// 读 出 该 数组 第 一 个 元 素 〈 代 表 记 录 总 条 数 ) 


1/ 计算 总 页 数 为 记录 总 条 数 除 以 每 页 显示 条 数 
/| 输入 总 页 数 


// 当 前 页 
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52 if($page!-ceil($temp[O]/Slist num)) // 如 果 当 前 页 不 是 最 后 一 页 

53 $current size-$list num; // 当 前 页 最 多 可 显示 $list_num 条 记录 
54 else // 如 果 当 前 页 是 最 后 一 页 

55 S$current_size=$temp[0]%Slist_num; /| 当前 页 显示 的 条 数 为 总 条 数 除 以 $lsit_num 的 余数 
56 if($current_size==0) 

57 $current size-$list num; // 如 果 正 好 是 显示 条 数 的 倍数 则 显示 $list_num 条 内 容 
58 echo "<table border-'1'»"; 

59 for($i=0;$i<$current_size;$i++) 

60 { 

61 $temp=explode("|l",$myfile[($page-1)*$list_num+9$i]);// 把 相应 的 记录 按 “||” 分 割 到 数组 
62 echo "<tr>"; 

63 echo "<td>"; 

64 echo "第 ".$temp[0]." 条 留言 "; /显示 记录 号 

65 echo "</td>"; 

66 echo "<td>"; 

67 echo "Ez: ".Stemp[1]; /显示 作者 

68 echo "</td>"; 

69 echo "<td>"; 

70 echo "5 T".Stemp[4]; // 显 示 留言 时 间 

71 if($ COOKIE[pass]--Ssuper pass) // 如 果 管 理 者 登录 ， 显 示 操 作 链 接 
72 ( 

73 echo "<a href-^18-4.php?id-" Stemp[0]."» 1&2 «/a»"; 

74 echo "&nbsp;&nbsp;"; 

75 echo "<a href='18-5.php?id=".$temp[0]."> 删 除 </a>"; 

76 ) 

77 echo "</td>"; 

78 echo "</tr>"; 

79 echo "<tr>"; 

80 echo "<td colspan-'3'»"; 

81 echo "主题 : ".$temp[2]; /显示 留言 主题 

82 echo "«/td»"; 

83 echo "</tr>"; 

84 echo "<tr>"; 

85 echo "<td colspan='3'>"; 

86 echo "内 容 : <br>".$temp[3]; /显示 留言 内 容 

87 echo "</td>"; 

88 echo "</tr>"; 

89 } 

90 echo "</table>"; 

91 } 

92 echo "<p>"; 

93 ?> 


94 <div id-"huifu" style-"display:none; position:absolute; left:15px; top:265px;"» 


95 <table border-1 bgcolor="#ffffff"> 


96 «form method="post" action-"«?php echo $PATH INFO; ?>"> 
97 <tr> 

98 <td colspan="2"> 请 输入 留言 内 容 </td> 

99 </tr> 

100 <tr> 

101 <td> 姓 名 : </td> 

102 <td><input name="name" type="text"></td> 


362 


103 
104 
105 
106 
107 
108 
109 
110 
111 
112 
113 
114 
115 
116 
117 
118 
119 
120 
121 
122 
123 
124 
125 
126 
127 
128 
129 
130 
131 
132 
133 
134 
135 
136 
137 
138 
139 
140 
141 
142 
143 
144 
145 
146 
147 
148 
149 
150 
151 
152 
153 
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</tr> 
<tr> 
<td> 主 题 : </td> 
<td><input name-"subject" type-"text"»«/td» 
«itr» 
«tr» 
«td colspan="2"> 内 容 : </td> 
«itr» 
<tr> 
<td colspan="2"> 
<textarea name="content" cols="36" rows="8"></textarea></td> 
«itr» 
<tr> 
<td colspan="2"> 
<input type="submit" name="Submit" value=" 确 定 "> 
«input type-"reset" name="Submit2" value=" 清 除 "> 
«input name="Submit3" type="button" onClick-"Showhide(huifu,0)" value=" 关 闭 "> 
</td> 
«ftr» 
</form> 


</table> 
</div> 
<?php 


/以 下 内 容 为 分 页 显示 链接 
$prev page-$page-1; 1/ 前 一 页 
$next_page=$page+1; /下 一 页 
if ($page<=1) 
{ 

echo "第 一 页 |"; 


else 
{ 
echo "<a href='$PATH_INFO?page=1'> 第 一 页 </a> |" 
) 
if ($prev page«1) 
it 
echo " E—7 |"; 


else 


{ 
echo "<a href='$PATH_INFO?page=$prev_page'> 上 一 页 </a> | "; 


) 
if ($next page»$p count) 


{ 
echo "R—Z |"; 
$ 
else 
ü 
echo "<a href-'$PATH INFO?page-$next page'» h — 9i«/a» |" 
} 


if ($page>=$p_count) 
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154 t 

155 echo "最 后 一 页 </p>\n"; 

156 } 

157 else 

158 

159 echo "<a href='$PATH_INFO?page=$p_count> 最 后 一 页 </a></p>\n"; 

160 H 

161 H 

162 else 

163 

164 $name-$ POST[name]: IRE 

165 $subject-$ POST[subject]; /获取 主题 

166 $content-$ POST[content]; /获取 内 容 

167 $time= date(Y 年 m 月 d 日 ); /获取 日 期 

168 $s-$name."||".$subject."||".Scontent."|".$time."n"; ”// 把 内 容 赋 给 变量 

169 $myfile=file($file_name); /使 用 file() 函 数 把 记录 文件 按 行 读 入 数组 
170 if($myfile[0]--"") 15058 xc 3s 

171 { 

172 $fp=fopen($file_name,"a+"); // 写 入 方式 打开 文件 

173 fwrite( $fp,"1||".$s); // 直 接 写 入 行 号 为 1 的 内 容 
174 fclose($fp); /关闭 文件 

175 i 

176 else 

177 H 

178 $tempzexplode("||",$myfile[0]); /把 第 一 条 记录 按 “|| ”分割 到 数组 
179 S$temp[0]++; // 得 出 总 记录 数 并 自 增 1 
180 $fp=fopen($file_name,"r"); /以 只 读 方式 打开 文件 

181 S$line_has=fread($fp,filesize("$file_name")); /使 用 fread() 函 数 读 出 文件 已 经 存在 的 内 容 
182 fclose($fp); /关闭 文件 

183 $fp-fopen(Sfile name,"w"); /以 写 入 方式 打开 文件 

184 fwrite(Sfp,Stemp[0]."||".Ss); // 写 入 新 的 内 容 

185 fwrite($fp,"$line_has"); // 写 入 原来 已 经 存在 的 内 容 
186 fclose($fp); /关闭 文件 

187 » 

188 ?» 

189 «html» 

190 «head» 

191 <title> 文 本 留言 板 一 一 记录 添加 页 </title> 

192 </head> 

193 «meta http-equiv-"refresh" content="2; url=18-2.php"> 

194 «body» 

195 已 经 成 功 更 改 记录 ， 两 秒 后 返回 。 

196 </body> 

197 </html> 

198 <?php 

199 } 

200 ?> 

201 </body> 

202 </html> 


技巧 : 在 实例 的 form 中 ，action 值 使 用 了 “S$PATH INFO” 预 定义 变量 简化 URL。 


e. 
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通过 查看 以 上 代码 ， 可 以 发 现 主要 是 使 用 了 对 文件 的 操作 ， 包 括 按 行 读 取 文件 内 容 ， 把 文件 内 容 
读 入 到 数组 等 。 
18.4.3 ”管理 入 口 页 的 创建 

GEH 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 18 章 \ 管 理 入 口 页 的 创建 .wmv 

管理 入 口 页 的 作用 是 把 有 管理 权限 的 登录 资料 保存 为 Cookie， 以 便 管理 者 对 留言 信息 做 相应 的 修 


改 。 登 录 密码 从 配置 文件 18-1.php 中 获取 。 
【实例 18-3】 以 下 代码 为 管理 入 口 页 。 


re 实例 18-3: 管理 入 口 
b 源码 路 径 : 光盘 \ 源 文件 \18\18-3.php 


<?php 

error reporting(0); 

ifI$ POST[pass]) // 如 果 没 有 输入 管理 员 名 称 ， 则 显示 HTML 内 容 
?> 
<html> 
<head> 
<title> 管 理 入 口 </title> 
</head> 
<body topmargin="50" > 
<script language=javascript> 
function juge(form) 
li 


if (form.pass.value == "") 


alert(" 请 输入 密码 人 "); 
theForm.pass.focus(); 
return (false); 
$ 
} 
</script> 
<center> 
<h1> 管 理 留言 板 入 口 </h1> 
<p> 
<a href="18-2.php"> 返 回首 页 </a> 
«table border="1"> 
«form action="<?php echo $PATH INFO; ?>" method=post onsubmit="return juge(this)"» 
«tr» 
«td colspan="2"><center> 管 理 留言 板 </center></td> 
<hr> 
<tr> 
«td» fa «/td» 
<td><input type-password name-pass? «/td» 
<hr> 
«tr» 
«td colspanz"2"»«center»«input type=submit value=" 登 录 "></center></td> 
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37 «tr 

38 </form> 

39 </table> 

40 </center> 

41 </body> 

42 </html> 

43 <?php 

44 ) 

45 else // 如 果 存 在 密码 ， 则 执行 操作 
46 { 

47 require "18-1.php"; // 调 用 配置 文件 
48 if($ POST[pass]!-$super pass) // 如 果 密 码 错误 
49 { 

50 ?> 

51 <html> 

52 <head> 

53 ”<title> 文 本 留言 板 一 一 管理 入 口 </title> 

54 </head> 

55 <meta http-equiv="refresh" content="2; url=18-3.php"> 

56 <body> 

57 ”登录 失败 ， 密 码 错误 ! «p» 

58 ”两 秒 后 返回 。 

59 </body> 

60 </html> 

61 <?php 

62 » 

63 else // 如 果 密 码 正确 


t 
65 setcookie("pass",$ POST[pass); /注册 Cookie 
66 ?> 
67 «html» 
68 «head» 
69 ”<title> 文 本 留言 板 一 一 管理 入 口 </title> 
70 </head> 
71 <meta http-equiv="refresh" content="2; url=18-2.php"> 
72 <body> 
73 ”登录 成 功 ! <p> 
74 ”两 秒 后 进入 管理 页 。 
75 </body> 
76 </html> 
77 <?php 
78 } 
79 ) 
80 ?> 


说 明 : 该 实例 中 主要 的 工作 就 是 进行 一 个 简单 的 登录 判断 。 


该 文件 只 是 进行 了 简单 的 判断 ， 并 根据 不 同 的 结果 跳 转 到 不 同 的 页 面 。 如 果 密 码 正确 ， 则 把 信息 
写 入 Cookie 数据 。 


e. 
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18.4.4 修改 留言 页 面 的 创建 


EB 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 18 章 \ 修 改 留言 页 面 的 创建 .wmv 

如 果 留 言 中 出 现 了 不 合适 的 内 容 ， 理 应 把 它们 修改 掉 ， 这 时 就 需要 使 用 修改 留言 页 面 来 操作 。 修 
改 留言 的 实质 是 读 出 某 一 条 留言 的 内 容 并 用 新 内 容 代 蔡 该 原 有 内 容 ， 其 实质 还 是 对 文件 的 操作 。 

【实例 18-4】 以 下 代码 为 修改 留言 内 容 的 页 面 。 


re 实例 18-4: 修改 留言 内 容 
E. 源码 路 径 ， 光 盘 \ 源 文件 \18\18-4.php 


01 <?php 

02 error reporting(0); 

03 require "18-1.php"; 

04 ifI$ POST[content]) // 如 果 没 有 提交 ID 

05 { 

06 if(!$_GET['id"]) // 如 果 没 有 指定 修改 ID 

07 { 

08 echo "没有 指定 ID"; 

09 exit(); 

10 H 

11 $id-$ GET['id"]; /把 参数 ID 赋值 给 变量 

12 $myfile=file($file_name); /使 用 file() 函 数 把 文件 按 行 读 入 到 数组 
13 $z=$myfile[0]; /| 数组 第 一 个 元 素 赋值 给 变量 

14 $temp=explode("||",$myfile[$z-$id]); /使 用 explode 分 割 相应 记录 到 数组 
(15092 

16 «html» 

17 <head> 

18 ”<title> 文 本 留言 板 一 一 修改 留言 </title> 

19 </head> 

20 <body> 


21 <center> 

22 ”<h1> 文 本 留言 板 一 一 修改 留言 </h1> 

23 «p» 

24 ”<h3> 只 有 留言 主题 与 留言 内 容 是 可 以 改变 的 </h3> 

25 «p» 

26 <a href=18-2.php> 返 回首 页 </a> 

27 <table border=1> 

28 <form method="post" action-"«?php echo $PATH INFO; ?>"> 
29 <input type=hidden value-"«?php echo $temp[0]; ?>" name-id» 
30 <tr> 

31 «td colspan="2"> 以 下 为 第 <?php echo $temp[0]; ?> 条 留言 的 内 容 </td> 
32 «ltr» 

33 «tr 

34 ”<td> 姓 名 : </td> 

35 <td><?php echo $temp[1]; ?></td> 

36 </tr> 

37 <tr> 

38 <td>: </td> 
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39 <td><input name-"subject" type="text" value=<?php echo $temp[2]; ?>></td> 
40 «ftr» 
41 <tr> 
42 <td colspan="2"> 内 容 : </td> 
43 «ftr» 
44 <tr> 
45 <td colspan-"2"» 
46  «textarea name-"content" cols="36" rows-"8"»«?php echo $temp[3]; ?»«/textarea» 
47 «ltd» 
48 «ltr» 
49 <tr> 
50 <td colspan-"2"» 
51 <input type="submit" name-"Submit" value=" 确 定 "> 
52 <inputtype="reset" name-"Submit2" value=" 清 除 "> 
53 </td> 
54 </tr> 
55 </form> 
56 </table> 
57 </center> 
58 </body> 
59 </html> 
60 <?php 
61 } 
62 else 
63 { 
64 $id=$_POSTŢ'id']; /定义 ID 
65 $subject-$ POST[subject]; 
66 $content-$ POST[content]; /定义 内 容 
67 $myfile=file($file_name); /使 用 file() 函 数 把 文件 按 行 读 入 到 数组 
68 $z=$myfile[0]; /数组 第 一 个 元 素 赋值 给 变量 
69 $temp=explode("]|",$myfile[$z-$id]); // 使 用 explode 分 割 相应 记录 到 数组 
70 $s-S$temp[0]."|| .Stemp[1]."||".Ssubject."||".Scontent."||".Stemp[4]; 
71 for($i=0;$i<($z-$id);$i++) 
72 
73 $text2=$text2.$myfile[$i]; // 内 容 保 持 不 变 
74 } 
75 for($i=($z-$id+1);$i<$z;$i++) // 将 欲 删除 记录 的 后 一 条 记录 作为 最 后 一 条 记录 
76 
77 $text1=$text1.$myfile[$i]; /内 容 保持 不 变 
78 H 
79 $fp-fopen($file name,"w"); /以 写 入 方式 打开 文件 〈 文 件 同 时 被 清空 ) 
80 fwrite($fp, $text2); // 写 入 欲 删 除 记录 之 前 的 所 有 记录 
81 fwrite($fp,$s); // 写 入 更 改过 的 记录 
82 fwrite($fp, $text1); // 写 入 欲 删 除 记录 之 后 的 所 有 记录 
83 fclose($fp); /关闭 文件 
84 ?> 
«html» 
<head> 
<title> 文 本 留言 板 一 一 修改 留言 </title> 
</head> 


<meta http-equiv="refresh" content="2; url=18-2.php"> 
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90 «body» 
91 ”修改 成 功 ! <p> 
92 ”两 秒 后 返回 。 
93 </body> 

94 </html> 

95 <?php 

96 } 

97 7> 


说 明 : 该 实例 的 核心 就 是 将 数据 库 中 的 信息 进行 显示 并 将 修改 后 的 内 容 写 回 数 据 库 。 


以 上 代码 实现 了 对 文本 文档 的 复杂 操作 。 不 过 从 以 上 代码 可 以 发 现 ， 文 本 留言 板 相当 低 效 。 为 了 
修改 一 条 留言 ， 就 不 得 不 把 所 有 留言 内 容 读 入 内 存 。 不 过 因为 现在 连 最 一 般 的 PC 机 处 理 数据 的 速度 也 
是 相当 快 的 ， 所 以 使 用 文本 留言 板 的 速度 瓶颈 并 不 是 特别 明显 。 


18.4.5 ”删除 留言 页 面 的 创建 
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网 上 的 所 有 留言 板 都 面临 着 一 个 问题 的 困扰 一 一 恶意 灌水 。 对 那些 恶意 灌水 的 留言 记录 ， 要 及 时 
删除 。 这 样 一 方面 可 以 减少 空间 的 占用 ， 另 一 方面 还 可 以 使 整个 留言 本 页 面 显 得 干净 整洁 。 

【实例 18-5】 以 下 代码 为 删除 留言 页 面 。 


c 实例 19-5. 删除 留言 

u. b | 。 源码 路 径 ， 交 得 \ 源 文件 SNl8-5 php 

01 <?php 

02 error_reporting(0); 

03 require "18-1.php"; 

04 Sid-$ GET['id"]; // 把 参数 ID 赋值 给 变量 

05 if(ISid) // 如 果 没 有 指定 删除 ID 

06 ( 

07 echo "没有 指定 ID"; 

08 exit(); 

09 H 

10 $myfile-file($file name); /使 用 fille() 函 数 把 文件 按 行 读 入 到 数组 
11 $z-$myfile[0]; /| 数组 第 一 个 元 素 赋值 给 变量 

12 S$temp=explode("||",$myfile[$z-$id]); // 使 用 explode 分 割 相应 记录 到 数组 
13 for($i=0;$i<($z-$id);$i++) 

14 ( 

15 S$temp2-explode("||",Smyfile[Si]); /使 用 explode 分 割 相应 记录 到 数组 
16 S$temp2[0]--; /| 记录 号 实现 自 减 

17 Stext2-$text2.$temp2[0]."||".Stemp2[1]."]|'.-Stemp2[2]."||".Stemp2[3]."||".Stemp2[4]; 
18 /把 新 的 内 容 赋值 到 变量 

19 H 

20 for($i=($z-$id+1);$i<$z;$i++) // 将 欲 删除 记录 的 后 一 条 记录 作为 最 后 一 条 记录 
21 f 

22 $text1=$text1.$myfile[$i]; TIVA E 

23 ) 
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24 $fp-fopen(Sfile name,"w"); /以 写 入 方式 打开 文件 〈 文 件 同时 被 清空 ) 
25 fwrite($fp,$text2); // 写 入 欲 删除 记录 之 前 的 所 有 记录 
26 fwrite($fp,$text1); // 写 入 欲 删除 记录 之 后 的 所 有 记录 
27 fclose($fp); /关闭 文件 

28 ?» 

29 «html» 

30 «head» 

31 ”<title> 文 本 留言 板 一 一 删除 留言 </title> 

32 </head> 

33 <meta http-equiv-"refresh" content="2; url=18-2.php"> 

34 «body» 

35 ”删除 成 功 ! <p> 

36 ”两 秒 后 返回 。 

37 </body> 

38 </html> 


说 明 : 该 实例 的 实现 非常 简单 ， 就 是 删除 指定 ID 的 留言 内 容 。 


该 文件 的 实现 方法 是 先 读 出 欲 删除 留言 记录 之 前 的 所 有 记录 , 并 把 它们 的 记录 号 全 部 自 减 1。 再 读 
出 欲 删除 留言 记录 后 的 所 有 记录 ， 保 持 不 变 。 然 后 ， 再 把 修改 过 的 记录 全 部 写 入 文件 ， 这 样 原 有 的 欲 
删除 的 记录 就 会 从 文件 中 “删除 ”。 实 质 上 是 重新 写 入 了 不 被 删除 的 文件 。 

至 此 ， 该 文本 留言 板 的 所 有 页 面 就 全 部 完成 了 。18.5 节 就 要 对 该 系统 做 一 下 测试 了 。 
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F 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 18 章 \ 调 试 运行 留言 板 .wmv 
第 一 步 ， 先 在 PHP 运行 环境 下 执行 实例 18-2。 由 于 是 第 一 次 运行 ， 所 以 结果 如 图 18.1 所 示 。 
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图 18.1 第 一 次 执行 显示 留言 页 执行 结果 

由 于 此 时 还 没有 任何 留言 ， 所 以 显示 记录 条 数 为 0。 不 过 查看 18-2.php 所 在 的 路 径 会 发 现 多 了 一 
个 名 为 data.dat 的 空 文件 ， 说 明 创 建 数据 文件 成 功 。 这 时 可 以 单 击 “ 签 写 留 言 ”链接 来 测试 插入 记录 功 
能 是 否 正 常 。 单 击 该 链接 后 ， 在 页 面 下 方 会 出 现 输入 表单 ， 如 图 18.2 所 示 。 

在 如 图 18.2 所 示 的 表单 中 输入 相应 的 内 容 ， 然 后 单 击 “确定 ”按钮 。 出 现 如 图 18.3 所 示 的 结果 。 

留言 添加 成 功 后 ， 直 接 又 跳 转 了 回来 。 从 图 18.3 可 以 看 出 ， 留 言 已 经 成 功 添加 并 显示 。 打 开 留 言 
板 程序 目录 下 的 data.dat 文件 ， 其 中 内 容 如 下 所 示 ; 

人 无名氏 | 今天 天 气 不 错 || 今 天 天 气 不 错 ， 不 热 也 不 冷 。||2013 年 05 H 13 日 
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RED 
[今天 天 气 不 异 ， 不 热 也 不 符 。 
Wwe | -|xma 第 一 页 | 上 一 页 | 下 一 页 | 最 后 一 页 
^D ~ R100% ~ 
图 18.2 ”显示 隐藏 的 表单 执行 结果 图 18.3 添加 留言 执行 结果 


可 见 ， 已 经 将 相关 信息 正确 添加 至 记录 文件 。 
下 面 来 测试 管理 入 口 。 单 击 “ 管 理 入 口 ” 链 接 后 ， 出 现 如 图 18.4 所 示 的 执行 结果 。 
输入 正确 的 密码 (这 里 输入 前 面 18-1.php 中 定义 的 Ssuper_pass 的 值 ) ， 并 单 击 “登录 ” 按 钮 后 ， 


执行 结果 如 图 18.5 所 示 。 
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图 18.4 管理 留言 板 执行 结果 图 18.5 正确 登录 管理 执行 结果 


对 比 图 18.3 与 图 18.5 TURI, K 18.5 EE 18.3 上 每 一 条 留言 后 面 都 多 了 “修改 ”与 “删除 ” 
的 链接 ， 说 明 已 经 正常 登录 并 可 以 进行 相关 操作 。 

由 于 现在 留言 板 中 记录 较 少 ， 所 以 继续 添加 一 些 记 录 ， 以 测试 相关 内 容 。 

单 击 图 18.5 中 的 “修改 ”链接 ， 将 打开 如 图 18.6 所 示 的 执行 结果 。 

按照 需要 进行 修改 ， 这 里 把 主题 中 的 “今天 天 气 不 错 ” 改 为 “今天 天 气 为 什么 不 错 ? ”， 其 他 的 
内 容 保持 不 变 ， 单 击 “ 确 定 ” 按 钮 ， 执 行 结果 如 图 18.7 所 示 。 


KA ea 


En) 
Q^ ED dE 


文本 留言 板 一 一 修改 留言 


只 有 留言 主题 与 留言 内 容 是 可 以 改变 的 ER 
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图 18.6 修改 记录 的 前 台 执行 结果 图 18.7 修改 后 的 执行 结果 
从 图 18.7 的 执行 结果 可 以 看 出 ， 留 言 内 容 已 经 按照 用 户 的 输入 进行 了 更 改 ， 说 明 修 改 留言 功能 运 
行 正常 。 
下 面 测试 程序 的 删除 功能 。 删 除 前 的 记录 情况 如 图 18.8 所 示 。 


下 面 把 图 18.8 中 的 第 2 条 留言 删除 。 单 击 “删除 ”链接 执行 18-5.php。 删 除 操作 后 的 执行 结果 如 
图 18.9 所 示 。 
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图 18.8 ”删除 操作 前 的 执行 结果 18.9 删除 操作 后 的 执行 结果 
对 比 图 18.8 与 图 18.9 可 以 发 现 留言 数量 由 原来 的 2 条 变 成 了 1 条 。 至 此 , 整个 系统 全 部 测试 完毕 。 


18.6 ”进一步 完善 


GE 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 18 章 \ 进 一 步 完善 wmv 
这 个 文本 留言 板 对 于 个 人 用 户 来 说 基本 上 已 经 够 使 用 了 。 不 过 ， 对 要 求 比较 多 的 用 户 来 说 ， 该 留 
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言 板 还 是 有 需要 完善 的 地 方 。 第 一 ， 留 言 板 没有 回复 功能 。 第 二 ， 留 言 板 存在 安全 隐患 。 第 三 ， 留 言 
板 的 内 容 还 不 够 丰富 ， 如 提交 留言 时 没有 可 以 使 用 的 表情 图 片 之 类 的 功能 。 

对 于 这 些 问题 ， 作 者 只 提供 解决 思路 ， 有 兴趣 的 读者 可 以 自行 研究 以 丰富 这 个 文本 留言 板 。 

对 于 第 一 个 问题 ， 留 言 板 没有 回复 功能 。 解 决 起 来 相对 麻烦 一 些 ， 可 以 给 留言 数据 在 原来 的 5 项 
(留言 ID、 作 者、 题目 、 内 容 、 留 言 时 间 ) 的 基础 上 再 增加 一 项 r id。 该 项 只 记录 父 留言 的 ID， 如 果 
某 一 条 留言 本 身 就 是 父 留言 , 则 r id 的 值 为 0。 然后 在 显示 一 条 编号 为 ID 的 留言 时 遍历 它 后 面 所 有 r_id= 
父 留言 ID 的 记录 作为 回复 显示 。 虽 然 这 样 能 够 实现 , 但 在 删除 留言 特别 是 删除 父 留言 时 就 会 相当 麻烦 。 
这 也 是 文本 留言 板 自身 的 一 个 局 限 性 。 

现在 这 个 留言 板 有 什么 安全 隐患 呢 ? 因为 没有 对 用 户 的 输入 进行 相应 的 屏蔽 ， 所 以 用 户 可 以 使 用 
HTML 代码 。 这 在 通常 情况 下 是 不 被 允许 的 。 不 过 解决 起 来 很 简单 ， 就 是 使 用 htmlspecialchars() 函 数 对 
用 户 的 输入 做 相应 的 处 理 。 这 样 输入 的 HTML 代码 就 会 变 成 普通 的 文本 ， 不 再 具有 威胁 性 了 。 

添加 表情 ， 也 不 复杂 ， 只 需 给 原来 的 数据 再 增加 一 项 ， 里 面 存放 小 图 片 的 链接 。 显 示 时 ， 显 示 相 
应 的 表情 符号 或 者 小 图 片 即 可 。 
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虽然 文本 留言 板 有 其 局 限 性 ， 功 能 上 还 不 够 强大 ， 但 只 要 善于 通过 不 同 的 方法 去 解决 现实 问题 ， 
文本 留言 板 还 是 有 用 武之 地 的 。 通 过 本 章 的 学 习 ， 相 信 读 者 对 于 如 何 建立 并 使 用 一 个 文本 留言 板 都 有 
一 个 深刻 的 认识 了 。 概 括 来 说 ， 文 本 留言 板 的 实质 还 是 对 文本 文件 的 操作 。 
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如 果 要 问 当前 最 流行 的 网 络 应 用 是 什么 ， 既 不 是 曾经 流行 过 的 E-mail (电子 邮件 ) 、BBS (电子 
公告 板 或 者 论坛 ) ， 也 不 是 正在 流行 的 ICQ 〈 即 时 聊天 ) ， 而 是 博客 。 关 于 博客 的 说 法 和 比喻 网 上 有 
这 样 几 种 : (1) 博客 是 继 E-mail. BBS, ICQ 之 后 出 现 的 第 四 种 网 络 交流 方式 。 (2) 博客 是 网 络 时 
代 的 个 人 “读者 文摘 ”。 (3) 博客 是 以 超 链接 为 武器 的 网 络 日 记 。 (4) 博客 是 信息 时 代 的 麦哲伦 。 
(5) 博客 代表 着 新 的 生活 方式 和 新 的 工作 方式 ， 更 代表 着 新 的 学 习 方 式 。 通 过 博客 ， 让 自己 学 到 很 多 ， 
让 别人 学 到 更 多 。 (0 博客 代表 着 “新 闻 媒 体 3.0 版 ”: 旧 媒 体 Cold media). 一 新 媒体 (new media) 一 
自 媒体 (we media) 。 

总 之 ， 博 客 是 一 个 正 处 于 快速 发 展 和 快速 演变 中 的 互联 网 新 应 用 。 所 以 ， 对 于 一 个 PHPer (PHP f 
序 员 ) 来 说 , 了解 如 何 写 出 高 效 的 博客 程序 是 十 分 必要 的 。 本 章 就 向 读者 介绍 一 下 如 何 使 用 PHP 和 MySQL 
数据 库 结合 来 制作 一 个 简单 的 博客 程序 。 本 章 内 容 包 括 : 什么 是 博客 、 简 单 的 博客 程序 的 功能 、 博 客 程 
序 的 代码 实现 等 。 通 过 本 章 的 学 习 ， 读 者 会 对 什么 是 博客 、 如 何 写 出 博客 程序 有 本 质 上 的 认识 。 


19.1 什么 是 博客 
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要 想 写 出 博客 程序 ， 第 一 步 就 是 要 先 搞 明白 ， 到 底 什么 是 博客 ， 本 节 就 来 回答 这 个 问题 。 

中 文 “博客 ”一 词 ， 源 于 英文 单词 Blog/Blogger。Blog， 是 Weblog 的 简称 。Weblog， 其 实 是 Web 
和 Log 的 组 合 词 。Web， 指 World Wide Web 即 互联 网 ， Log 的 原 义 则 是 “航海 日 志 ”， 后 指 任何 类 型 
的 流水 记录 。 合 在 一 起 理解 ，Weblog 就 是 在 网 络 上 的 一 种 流水 记录 形式 或 者 简称 “网 络 日 志 ”。 

Blogger 或 Weblogger， 是 指 习惯 于 日 常 记 录 并 使 用 Weblog 工具 的 人 。 虽 然 在 中 国 早 期 对 此 概念 
的 译名 不 尽 相同 (有 的 称 为 “网 志 ”， 有 的 称 为 “网 录 ” 等 ) ， 但 目前 已 基本 统一 到 “博客 ”一 词 上 
来 。 该 词 最 早 是 在 2002 年 8 月 8 日 由 著名 的 网 络 评论 家 王 俊秀 和 方兴东 共同 撰文 提出 来 的 。 博客 也 好 ， 
WEEER, 仅仅 是 一 种 名 称 而 已 ， 它 的 本 义 不 会 超出 Weblog 的 范围 。 通 常 所 说 的 “博客 ”， 既 可 用 作 
名 词 Blogger 或 Weblogger 一 一 指 具 有 博客 行为 的 一 类 人 ; 也 可 以 用 作 动 词 ( 相 当 于 英文 中 的 Weblog 
或 blog) ， 指 博客 们 采取 的 具有 博客 行为 反映、 是 第 三 方 可 以 用 视觉 感受 到 的 行为 ， 即 博客 们 所 撰写 
的 Blog。 因 此 ，“ 他 /她 是 一 位 博客 ， 他 /她 天 天 在 博客 ”及 “博客 博 什 么 客 ?” 在 中 文 语法 与 逻辑 上 都 
是 正确 的 ， 只 是 不 同 场合 的 用 法 不 同 罢了 。 

Blog 究竟 是 什么 ? 其 实 一 个 Blog 就 是 一 个 网 页 ， 它 通常 是 由 简短 且 经 常 更 新 的 帖子 (Post) 所 构 
成 ， 这 些 张 贴 的 文章 都 按照 年 份 和 日 期 倒序 排列 。Blog 的 内 容 和 目的 有 很 大 的 不 同 ， 从 对 其 他 网 站 的 
链接 、 评 论 、 有 关公 司 和 个 人 构想 的 新 闻 ， 到 上 日记、 照片 、 诗 歌 、 散 文 ， 甚 至 科幻 小 说 的 发 表 或 张贴 
都 有 。 许 多 Blogs 只 是 记录 着 Blogger 个 人 所 见 、 所 闻 、 所 想 ， 还 有 一 些 Blogs 则 是 一 群 人 基于 某 个 特 
定 主题 或 共同 利益 领域 的 集体 创作 。 
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192. 简单 博客 程序 的 功能 
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19.1 节 为 读者 介绍 了 什么 是 博客 ， 本 节 就 接着 来 讲 简单 博客 程序 所 应 具有 的 功能 。 

通常 一 个 最 简单 的 博客 程序 应 具有 以 下 功能 : 

回 ”博客 所 有 者 可 以 添加 日 志 。 

Ep ”普通 浏览 者 无 权 添 加 日 志 ， 只 能 对 已 经 存在 的 内 容 进行 评论 。 

回 ”所 有 者 可 以 管理 日 志 。 内 容 包括 删除 、 编 辑 日 志 ; 增加 、 删 除 、 更 改 日 志 的 类 别 以 及 可 以 设 
定 日 志 的 保密 状态 、 注 册 用 户 与 普通 用 户 的 权限 等 。 

回 ”通常 情况 下 ， 日 志 还 附带 一 个 留言 板 ， 供 普通 浏览 者 与 博客 的 所 有 者 进行 有 效 的 交流 。 

回 “” 除 此 之 外 ， 还 可 以 用 一 个 简单 的 用 户 注册 、 登 录 系 统 ， 以 使 普通 浏览 者 与 注册 用 户 有 不 同 的 权限 。 


193 ”制作 前 的 准备 工作 


通过 前 两 节 的 介绍 ， 读 者 对 于 什么 是 博客 程序 、 一 个 简单 的 博客 程序 所 应 具备 的 功能 应 该 有 一 个 
大 致 的 认识 了 。 从 本 节 开 始 就 来 通过 PHP 代码 一 步 步 实现 简单 博客 的 所 有 功能 。 


19.3.1 配置 文件 的 创建 
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配置 文件 是 程序 各 种 资源 访问 的 源头 ， 其 中 存放 着 连接 博客 程序 数据 库 的 主机 名 、 连 接 主机 的 用 
户 名 、 密 码 、 数 据 库 名 、 表 名 等 重要 信息 。 

【实例 19-1】 以 下 代码 为 博客 程序 的 配置 文件 。 


K 实例 19-1: 博客 程序 的 配置 文件 
源码 路 径 光盘 \ 源 文件 \19\19-1.php 


01 <?php 

02 S$host-"localhost"; /| 主机 名 
03 S$user-"root"; IIa P 
04 $pass-"admin"; /用 户 密码 
05 $db name-"'test"; /| 数据 库 名 
06 S$table_log="b_log"; IB: 

07 $table user-"b user"; IIR P 
08 $table gbook-"b gbook"; IRER 
09 $table_sort="b_sort"; /类 别 表 
10 ?> 


注意 : 这 里 的 数据 库 密码 一 定 要 对 应 安装 MYSQL 数据 库 时 设置 的 密码 。 
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19.3.2 ”安装 文件 的 创建 
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本 小 节 来 创建 一 个 安装 文件 ， 该 文件 的 作用 


是 从 配置 文件 (19-1.php) 中 获取 基本 信息 ， 然 后 提供 


给 用 户 一 个 表单 。 当 用 户 按 要 求 填写 所 需 数据 后 ， 执 行 创建 表 及 插入 记录 的 操作 ， 完 成 程序 表 的 创建 。 


【实例 19-2】 以 下 代码 为 安装 文件 。 


实例 19-2: 安装 文件 
源码 路 径 : 光盘 \ 源 文件 \19\19-2.php 


01 <?php 

02 error reporting(0); 

03 i$ POST[admin']) /如果 没 有 默认 参数 ， 则 显示 HTML 
04 { 

05 echo "<html>"; 

06 echo "<head>"; 

07 echo "<title> 安 装 程序 </title>"; 

08 echo "</head>"; 

09 echo "<body>"; 

10 echo "<script language=\"javascript\">"; 
11 echo "function juge(theForm)"; 

12 echo "f"; 

13 echo "if (theForm.admin.value == \"\")"; 
14 echo "f"; 

15 echo "alert(\" 请 输入 管理 员 名 称 ! V)"; 

16 echo "theForm.admin.focus();"; 

irf echo "return (false);"; 

18 echo "^ 

19 echo "if (theForm.pass.value == \"\")"; 

20 echo "{"; 

21 echo "alert(\" 请 输入 管理 员 密码 ! V)": 

22 echo "theForm.pass.focus();"; 

23 echo "return (false);"; 

24 echo "}"; 

25 echo "if (theForm.pass.value.length « 8 )"; 
26 echo "{"; 

27 echo "alert(\" 密 码 至 少 要 8 fù! Vy" 

28 echo "theForm.pass.focus();"; 

29 echo "return (false);"; 

30 echo "}"; 

31 echo "if (theForm.re pass.value !-theForm.pass.value)"; 
32 echo "("; 

33 echo "alert(\" 确 认 密码 与 密码 不 一 致 ! V)": 
34 echo "theForm.re pass.focus();"; 

95 echo "return (false);"; 

36 echo "^; 

37 echo "if (theForm.nickname.value == \"\")"; 
38 echo "{"; 

39 echo "alert(\" 请 输入 昵称 ! Vy"; 
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else 
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echo "theForm.nickname .focus();"; 

echo "return (false);"; 

echo ""; 

echo ""; 

echo "</script>"; 

echo "<center>"; 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\" align2 center" bgcolor= \"#000000\">"; 
echo "<form method=\"post\" action=\"$PATH_INFO\" onsubmit=\"return juge(this)\">"; 
echo "<tr bgcolor=\"#cccc99\">"; 

echo "<td colspan=\"2\" align=\"center\"><font size=\"5px\"> 安 装 博 客 </font></td>"; 
echo "</tr>"; 

echo "<tr bgcolor=\"#cccc99\">"; 

echo "<td> 管 理 员 : 〈 后 台 登 录 ) </td>"; 

echo "<td><input type=\"text\" name=\"admin\"></td>"; 

echo "</tr>"; 

echo "<tr bgcolor=\"#cccc99\">"; 

echo "<td> 管 理 员 密码 : 〈 不 小 于 8 位 ) </td>"; 

echo "<td><input type=\"password\" name=\"pass\" size=\"21\"></td>"; 

echo "</tr>"; 

echo "<tr bgcolor=\"#cccc99\">"; 

echo "<td> 确 认 密 码 : </td>"; 

echo "<td><input type=\"password\" name=\"re_pass\" size=\"21\"></td>"; 

echo "</tr>"; 

echo "<tr bgcolor=\"#cccc99\">"; 

echo "<td> 管 理 员 E-mail: (mE) </td>"; 

echo "<td><input type=\"text\" name=\"email\"></td>"; 

echo "</tr>"; 

echo "<tr bgcolor=\"#cccc99\">"; 

echo "<td> 管 理 员 昵称 : (MARR) </td>"; 

echo "<td><input type=\"text\" name=\"nickname\"></td>"; 

echo "</tr>"; 

echo "<tr bgcolor=\"#cccc99\">"; 

echo "<td colspan=\"2\"><center><input type=\"submit\" valuezV F—#\"></center></td>"; 
echo "</tr>"; 

echo "</form>"; 

echo "</table>"; 

echo "</center>"; 

echo "</body>"; 

echo "<html>"; 


// 如 果 有 POST 参数 执行 操作 


$username=$_POST['admin']; // 获 得 参数 
$password-md5($ POST[pass7); 

$nickname-$ POST[nicknameT; 

$email-$ POST[email'; 

require "19-1.php"; 

Slink=mysql_connect($host, $user,$pass) or die(mysql error()); 
mysql select db($db name.$link); /选择 数据 库 
$sql="create table $table log( 

id int(5) not null auto increment primary key, 
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91 p. id int(5) not null default 0, 

92 title varchar(40) not null default ", 

93 content text, 

94 sort varchar(20) not null default ", 

95 views int(5) not null default 0, 

96 tbcount int(5) not null default 0, 

97 author varchar(40) not null default", 

98 date varchar(20) not null default ", 

99 top enum('n';'y') not null default 'n', 

100 hide enum('n','y') not null default 'n', 

101 allow tb enum('n','y") not null default 'n' 

102 E 

103 mysql query($sql,Slink) or die(mysql error()); /发 送 创建 B_LOG 表 的 SQL 请 求 
104 $sql="create table $table user( 

105 id int(5) not null auto increment primary key, 

106 username varchar(40) not null default", 

107 password varchar(40) not null default ", 

108 admin enum('1','0') not null default 'O', 

109 nickname varchar(20) not null default ", 

110 sex enum('boy' girl") not null default 'boy', 

111 photo varchar(80) not null default ", 

112 email varchar(60) not null default ", 

113 description varchar(200) not null default " 

114 E 

115 mysql query($sql,Slink) or die(mysql error()); /发 送 创建 B USER 3&8 SQL 请 求 
116 $sql="create table $table gbook( 

117 id int(5) not null auto increment primary key, 

118 title varchar(40) not null default ", 

119 content text, 

120 author varchar(40) not null default ", 

121 date varchar(30) not null default " 

122 Je 

123 mysql query($sql.Slink) or die(mysql error()); /发 送 创建 B GBOOK 表 的 SQL 请 求 
124 $sql-"create table $table sort( 

125 id int(5) not null auto increment primary key, 

126 sortname varchar(20) not null default ", 

127 sortimg varchar(60) not null default ", 

128 sortnum int(5) not null default 0, 

129 description varchar(200) not null default " 

130 i5 

131 mysql_query($sql,$link) or die(mysql error()); /发 送 创建 B SORT 3&9 SQL 请 求 
132 $sql-"insert into $table sort(sortname,sortimg,description)values( Ek A 3€ 3I 'imagessort.img'," 
默认 的 分 类 ， 请 更 改 ! ")"; 

133 mysql_query($sql,$link) or die(mysql_error()); // 发 送 添加 默认 分 类 的 SQL 请 求 
134 $sql="insert into $table user(username, password, admin, nickname, email, description) values 
('Susername', '$password",'1','$nickname','$email',' 我 就 是 本 小 站 的 管理 员 ! ")"; 

135 mysql_query($sql,$link) or die(mysql error()); /发 送 添加 管理 员 信息 的 SQL 请 求 
136 echo "<html>"; 

137 echo "<head>"; 

138 echo "<title> Se X fe FF </title>"; 

139 echo "</head>"; 
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140 echo "<body>"; 

141 echo "</center>"; 

142 echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\" align=\"center\" bgcolor= \"#000000\">"; 
143 echo "<tr bgcolor=\"#cccc99\">"; 

144 echo "<td align=\"center\"><font size=\"5px\"> 安 装 博 客 </font></td>"; 
145 echo "</tr>"; 

146 echo "<tr bgcolor=\"#cccc99\">"; 

147 echo "<td align=\"center\"><font size=\"3px\"> 成 功 安装 ! «/font» «/td»"; 
148 echo "</tr>"; 

149 echo "<tr bgcolor=\"#cccc99\">"; 

150 echo "<td align=\"center\"> <a href=\"19-5.php\"> X 8 «/a» iE A </td>"; 
151 echo "</tr>"; 

152 echo "</table>"; 

153 echo "</center>"; 

154 echo "</body>"; 

155 echo "</html>"; 

156 

157 ?> 


说 明 : 本 实例 的 核心 就 是 创建 一 个 管理 员 账 号 并 且 创 建 需要 的 数据 表 。 


在 PHP 运行 环境 下 执行 该 PHP 文件 ， 以 完成 各 种 所 需要 的 表 的 创建 ， 其 首次 执行 结果 如 图 19.1 
所 示 。 
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图 19.1 安装 文件 首次 执行 结果 


按 图 19.1 的 要 求 填 入 用 户 信息 ， 然 后 单 击 “ 下 一 步 ” 按 钮 ， 将 会 开始 各 种 表 的 创建 工作 。 进 度 完 
成 之 后 的 执行 结果 如 图 19.2 所 示 。 
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图 19.2 ”安装 完成 后 的 执行 结果 


这 时 各 种 表 已 经 创建 完成 了 。 可 以 登录 进去 体验 一 下 博客 的 魅力 ， 但 是 现在 还 不 能 单 击 “ 这 里 ” 
的 链接 ， 因 为 相关 的 页 面 还 没有 被 创建 。 下 一 步 ， 就 来 创建 登录 的 页 面 。 
© 
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ED 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 19 章 \ 头 文件 的 创建 .wmv 
头 文件 ， 显 示 页 面 的 头 部 分 。 单 独 做 成 一 个 文件 ， 便 于 在 多 处 调用 ， 以 减少 代码 的 体积 。 
【实例 19-3】 以 下 代码 为 显示 页 面 的 头 文件 部 分 。 


re 实例 19-3. 显示 页 面 的 头 文件 
源码 路 径 : 光盘 \ 源 文件 \19\19-3.php 


01 <?php 

02 echo "<html>"; 

03 echo "<head>"; 

04 echo "<title> 博 客 程序 </title>"; 

05 echo "</head>"; 

06 echo "<body>"; 

07 echo "<style type=\"text/css\">"; 

08 echo "p (font-size: 12px; color:#0000ff}"; 

09 echo "table (table-layout: fixed; word-wrap:break-word;)"; 

10 echo "td (text-align: left; text-valign:center; font-size: 12px;)"; 

11 echo "body (font-size: 12px; text-decoration: none;color:*3300cc)"; 

12 echo "a (font-size: 12px; text-decoration: none; color: 0000FF)"; 

13 echo "a:hover ( color: #FF0000; text-decoration: underline)"; 

14 echo "a:link ( text-decoration: none]"; 

i5 echo "</style>"; 

16 echo "<center>"; 

qr echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\" align2 "center" bgcolor= \"#000000\">"; 
18 echo "<tr>"; 

19 echo "<td bgcolor=\"#fffffì\"></td>"; 

20 echo "<td bgcolor=\"#cccc99\"><center><a href=\"19-5.php\"> 首 页 </a></center></td>"; 
21 echo "<td bgcolor=\"#cccc99\"><center><a href=\"19-6.php\"> 日 志 </a></center></td>"; 
22 echo "<td bgcolor=\"#cccc99\"><center><a href=\"19-17.php\"> 留 言 </a></center></td>"; 
23 echo "<td bgcolor=\"#cccc99\"><center><a href=\"19-8.php\"> 管 理 </a></center></td>"; 
24 echo "</tr>"; 

25 echo "</table>"; 

26 echo "<p>"; 

EN es 


说 明 : 本 实例 是 为 了 精简 后 续 代 码 而 创建 的 。 


19.3.4 侧 边 文件 的 创建 
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通常 的 博客 程序 侧 边 显示 的 内 容 是 基本 相同 的 。 与 头 文件 一 样 ， 侧 边 也 可 以 单独 做 成 一 个 文件 ， 
需要 时 调用 即 可 。 这 样 做 的 好 处 显而易见 : 减少 代码 量 ， 减 轻 程序 更 改 工 作 量 。 如 果 需 要 对 某 一 部 分 
进行 修改 ， 直 接 修 改 该 文件 即 可 ， 而 不 用 对 页 面 文件 逐个 地 修改 。 侧 边 应 显示 以 下 内 容 : 

回 ”博客 管理 员 信息 。 


@ 
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回 用 户 登录 表单 。 

E ”如果 用 户 已 经 登录 ， 则 显示 登录 用 户 名 称 。 

回 日历， 以 便 使 用 者 可 以 根据 不 同日 期 查看 当天 的 日 志 。 
[ra] 

[ 


日 志 的 所 有 类 别 。 方 便 使 用 者 选择 不 同 的 类 别 。 
实例 19-4】 以 下 为 侧 边 文件 的 代码 。 


1 | EM 


源码 路 径 : 光盘 \ 源 文件 \19\19-4.php 


01 <?php 

02 echo "<table cellpadding=\"1\" cellspacing=\"1\" align=\"center\" bgcolor=\"#000000\">\n"; 
03 echo "<tr>"; 

04 echo "<td bgcolor=\"#eeeeff\">"; 

05 require "19-1.php"; // 调 用 配置 文件 
06 $link=mysql_connect($host,$user,$pass); /| 连接 主机 

07 mysql select db($db name,$link); // 选 择 数 据 库 

08 $sql="select * from $table user where admin-"1""; /显示 管理 员 信息 
09 $result-mysql query($sql,$link); /发 送 SQL 请 求 
10 $row-mysq| fetch array(Sresult); // 获 取信 息 

11 echo "管理 员 昵 称 : "; 

12 echo $row[nicknameT; /显示 昵称 

13 echo "<br>"; 

14 echo "E38 & IERI: "; 

15 echo $row[sex]; /显示 性 别 

16 echo "<br>"; 

17 echo "管理 员 信箱 : " 

18 echo $row['email']; // 显 示 信箱 

19 echo "<br>"; 

20 echo "E38 REIR: "5 

21 if($row[photo']) echo "<img src-images/".$row[photo].'»" /如 果 有 图 像 ， 则 显示 图 像 
22 echo "<br>"; 

23 echo "E38R EB: <br"; 

24 echo $row[description T; /显示 自白 

25 echo "</td>"; 

26 echo "</tr>"; 

27 echo "<tr>"; 

28 echo "<td bgcolor=\"#eeeeff\">"; 

29 if(!$_COOKIE['username']) // 如 果 没有 登录 用 户 
30 n 

31 echo "<form action-19-8.php method-post»"; /显示 登录 表单 
32 echo "用 户 名 : «input type=text name=username size-5» «br»"; 

33 echo "密码 : «input type=password name=password size=6><br>"; 

34 echo "<input type=submit value=\" 登 录 \">"; 

35 echo "<input type=button value=\" 注 册 \" onclick=w_open()>"; 

36 echo "</form>"; 

37 } 

38 else // 如 果 有 登录 用 户 
39 n 

40 echo "欢迎 你 :$_COOKIE[username] : /显示 登录 用 户 名 
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41 echo "<p alignzV' center": 

42 echo "<a href-19-18.php»iB i </a>"; /显示 “退出 ”链接 
43 H 

44 echo "</td>"; 

45 echo "</tr>"; 

46 echo "<tr>"; 

47 echo "<td bgcolor=\"#eeeeff\">"; IATA JS 显示 一 个 日 历 
48 echo "<form name=f> 

49 <select name=year size=1 onchange=change()>"; 
50 for($i=2005;$i<2016;$i++) 

51 { 

52 echo "<option value=".$i; 

53 if(Si--date("Y")) echo " selected "; 
54 echo "»" $i; 

55 ) 

56 echo "</select> 

57 «select name-month size=1 onchange-change()*"; 
58 for($i=1;$i<13;$i++) 

59 { 

60 echo "<option value=".$i; 

61 if($i==date("n")) echo " selected "; 
62 echo ">".$i; 

63 } 

64 echo "</select></form> 

65 <div id=a1></div> 

66 «script language-javascript> 

67 tian=new Array(); 

68 tian[0]=31; 

69 tian[1]=28; 

70 tian[2]=31; 

71 tian[3]=30; 

72 tian[4]-31; 

TE tian[5]=30; 

74 tian[6]=31; 

tian[7]=31; 

76 tian[8]=30; 

tian[9]=31; 

78 tian[10]=30; 

79 tian[11]=31; 

80 function change() 

81 { 

82 y=document.f.year.value; 

83 m=document.f.month.value; 

84 n=0,s=0; 

85 if(y%4==0) tian[1]=29; 

86 for(i=2005;i<y;i++) 

87 { 

88 if(i%4==0) n=366; 

89 else n=365; 

90 S=S+N; 

91 } 
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92 for(i=1;i<m;i++) 

93 { 

94 s-s-tian[i-1]; 

95 ) 

96 w-(s*6)967; 

97 a1.innerHTML=\'\"; 

98 content=\"<table><tr><td> A </td><td> 一 </td><td> 二 </td><td> = </td><td> 四 </td><td> 五 
«ftd» «td» 7zx«/td» «/tr» V; 

99 t=1; 

100 for(i=0;i<42;i++) 

101 f 

102 if(i%7==0) 

103 { 

104 content=content+\"<tr>\"; 

105 } 

106 if(i»-w)&&(i«(tianm-1])*w)) 

107 { 

108 content=content+\"<td><a href=19-6.php?y=\"+y+\"&m=\"+m+"&d=\"+t+">\"+t+\" </a></td>\"; 
109 ttt; 

110 } 

111 else 

112 ( 

113 content-content*" «td» &nbsp;«/td» V"; 

114 ) 

115 if(i%7==6) 

116 { 

117 content=content+\"</tr>\"; 

118 } 

119 } 

120 content=content+\"</table>\"; 

121 a1.innerHTML-content; 

122 ) 

123 change(); 

124 function w open() 

125 { 

126 open(\"19-18.php\"); 

127 ) 

128 «Iscript»"; 

129 echo "</td>"; 

130 echo "</tr>"; 

131 echo "<tr>"; 

132 echo "<td bgcolor=\"#eeeeff\">"; 

133 echo "日 志 类 别 : <br>"; 

134 $sql="select sortname,sortnum from $table sort"; /显示 所 有 日 志 类 别 
135 Sresult-mysql query(S$sql.Slink); /发 送 SQL 请 求 
136 while($rows=mysql_fetch_array($result) /循环 显示 类 别名 及 数量 
137 

138 echo "<a hre 仁 19-6.php?sort=".$rows[0].">".$rows[0]."</a> C".$rows[1].) "; 
139 echo "<br>"; 

140 } 

141 echo "</td>"; 
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142 
143 


144 ?> 


echo "</tr>"; 
echo "</table>"; 


说 明 : 通常 情况 下 导航 栏 都 会 作为 一 个 单独 的 文件 来 被 其 他 文件 包含 。 


194 日 志 显 示 模 块 


19.3 节 介绍 了 在 创建 程序 之 前 所 要 做 的 准备 工作 ， 并 建立 了 配置 文件 、 相 应 的 数据 库 和 表 、 显 示 
时 需要 调用 的 头 文件 与 侧 边 文件 ， 本 节 来 实现 日 志 显示 模块 。 该 模块 共 由 以 下 几 个 部 分 组 成 : 主 显示 
页 面 、 日 志 显示 页 面 、 单 条 日 志 详 细 信息 页 面 等 。 下 面 分 别 为 读者 做 介绍 。 


19.4.1 


主 显示 页 面 的 创建 


ED 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 19 章 \ 主 显示 页 面 的 创建 .wmv 

本 小 节 来 创建 该 博客 程序 的 主 显示 页 面 。 主 显示 页 面 即 用 户 首次 可 以 看 到 的 页 面 ， 除 了 调用 头 文 
件 与 侧 边 文件 显示 内 容 之 外 ， 它 还 有 以 下 几 个 内 容 : 显示 最 新 日 志 、 显 示 最 新 留言 。 

【实例 19-5】 以 下 为 主 显示 页 面 代码 。 


01 
02 
03 
04 
05 
06 
07 
08 
09 
10 
11 
12 
13 


«?php 


require "19-1.php"; // 调 用 配置 文件 
require "19-3.php"; // 调 用 头 文件 
echo "<table width=\"80%\">"; 

echo "<tr>"; 

echo "<td width=\"20%\">"; 

require "19-4.php"; 

echo "</td>"; 

echo "<td width=\"80%\">"; 

echo "<table cellpadding=\"1\" cellspacing=\"1\" width=\"100%\" align=\"center\" bgcolor=\"#000000\">"; 
echo "<tr>"; 

echo "<td bgcolor=\V#eeeeff"> 最 新 日 志 </td>"; 


echo "</tr>"; 
echo "<tr>"; 
echo "<td bgcolor=\"#eeeeff\">"; /显示 最 新 10 条 日 志 
$sql="select * from $table log where p_id=0 order by id desc limit 10"; 
Sresult-mysql query(S$sql.Slink); /发 送 SQL 请 求 
$nums=mysql_num_rows($result); // 获 取 日 志 数量 
if($nums«1) echo "还 没有 任何 日 志 记录 ! "; // 如 果 没 有 日 志 显示 信息 
else /如果 有 日 志 
while($rows=mysql_fetch_array($result)) // 通 过 循环 显示 内 容 
{ 


?> 
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echo "<a href=19-5.php?id=".$rows['id].">".$rows['title]."</a>"; 
echo "<p>"; 
echo $rows['date']; 
echo "<p>"; 
echo $rows['content"; 
echo "<p>"; 
echo "<a href=19-7.php?id=".$rows[id1."> 阅 读 全 文 </a>|"; 
echo "<a href=19-6.php?sort=".$rows['sort]."> 类 别 :".$rows['sort]."</a>|"; 
echo "<a href=19-7.php?id=".$rows['id]."> 评 论 (C".$rows['tbcount].") «/a»|"; 
echo "<a href=19-7.php?id=".$rows[id1."> 浏 览 (".$rows[views'].") </a>"; 
echo "<hr width=\"100%\">"; 
} 
} 
echo "</td>"; 
echo "</tr>"; 
echo "</table>"; 
echo "<p>"; 
echo "<table cellpadding=\"1\" cellspacing=\"1\" width=\"100%\" align=\"center\" bgcolor=\"#000000\">"; 
echo "<tr>"; 
echo "<td bgcolor=\"#eeeefh\"> 最 新 留言 </td>"; 


echo "</tr>"; 
echo "<tr>"; 
echo "<td bgcolor=\"#eeeeff\">"; // 显 示 最 新 10 条 留言 
S$sql-"select * from $table gbook order by id desc limit 10"; 
$result-mysql query($sql,$link); /发 送 SQL 请 求 
$nums-mysq| num rows($result); // 获 取 留 言 数量 
if($nums«1) echo "还 没有 任何 留言 !"; // 没 有 留言 时 显示 的 信息 
else // 如 果 有 留言 
while($rows=mysql_fetch_array($result)) // 通 过 循环 显示 内 容 
{ 
echo $rows[author]." 于 ".$rows[date]." 留 言说 : "; 
echo "<p>"; 
echo $rows['content]; 


echo "<hr width=\"100\">"; 


} 
} 
echo "</td>"; 
echo "</tr>"; 
echo "</table>"; 
echo "</td>"; 
echo "</tr>"; 
echo "</table>"; 
echo "</center>"; 
echo "</body>"; 
echo "</html>"; 


在 PHP 运行 环境 中 执行 该 PHP 文件 ， 执 行 结果 如 图 19.3 所 示 。 


D aaa 
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图 19.3 第 一 次 运行 主 显示 页 面 执行 结果 
注意 : 由 于 现在 的 数据 库 中 并 没有 任何 日 志 ， 所 以 这 里 均 显 示 为 空 。 


日 志 显示 页 面 的 创建 


Gl 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 19 章 \ 日 志 显示 页 面 的 创建 ,wmv 
本 小 节 来 创建 日 志 显 示 页 ， 该 页 面 的 作用 是 显示 所 有 已 经 存在 的 日 志 以 及 单条 日 志 的 浏览 量 、 评 论 


量 等 内 容 ， 并 且 还 具有 分 页 功能 。 
天 的 日 志 ， 则 


区 | 实例 19-6. 日 志 显示 页 面 


同时 还 应 该 根据 用 户 不 同 的 选择 显示 不 同 的 内 容 。 如 用 户 选择 了 某 一 


只 显示 某 一 天 的 内 容 ;， 如果 用 户 选择 了 某 一 类 别 的 日 志 ， 则 只 显示 某 一 类 别 的 内 容 。 
【实例 19-6】 以 下 为 日 志 显示 页 面 的 代码 。 


源码 路 径 光盘 \ 源 文件 \19\19-6.php 


<?php 


require "19-3.php"; 

echo "<table width=\"80%\">"; 
echo "<tr>"; 

echo "<td width=\"20%\">"; 
require "19-4.php"; 

echo "</td>"; 

echo "<td width=\"80%\">"; 


// 调 用 头 文件 


// 调 用 侧 边 文件 


echo "<table cellpadding=\"1\" cellspacing=\"1\" width=\"100%\" align=\"center\" bgcolor=\"#000000\">"; 


require "19-1.php"; 
Slink=mysql_connect($host, $user,$pass); 
mysql select db($db name.$link); 

if($ GET[y]Jand$ GET[m]and$ GET[d')) 


if($ GET[sort]) 


$sort-$ GET[sort]; 


// 调 用 配置 文件 


// 如 果 没有 日 期 输入 
// 如 果 有 类 别 输入 
/获取 类 别 
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echo "<tr>"; 
echo "<td bgcolor=\"#eeeefh"> 分 类 <font size=\"3\">[".$sort."]</font> 的 日 志 </td>"; 
echo "</tr>"; // 显 示 相 应 类 别 


$sql="select * from $table sort where sortname-'$sort"'; 
S$result-mysql query($sql,Slink); 
$rows-mysql fetch array(S$result); 
echo "<tr>"; 
echo "<td bgcolor=\V#eeee 从 "> 类 别 介绍 : ".$rows[description']."«/td»"; 
echo "</tr>"; 
echo "<tr>"; 
echo "<td bgcolor=\"#eeeefh"> 本 类 别 共 有 日 志 :“".$rows['sortnum1]." 篇 </td>"; 
echo "</tr>"; 
if($rows['sortnum']>0) 1/ 如 果 有 类 别 日 志 
{ 
echo "<tr>"; 
echo "<td bgcolor=\"#eeeeff\">"; 
$sql2="select * from Stable log where sort-'$sort' and p_id=0"; 
Sresult2=mysql_query($sql2, $link); 
while($rows2=mysql_fetch_array($result2))// 循 环 显示 
fi 
echo "<a href-19-7.php?id-" $rows2['id]."»" $rows2['title]."</a>"; 
echo "<p>"; 
echo $rows2[date'; 
echo "<p>"; 
echo $rows2['content]; 
echo "<p>"; 
echo "<a hrefz19-7.php?id-" $rows2[id']."» ik & Xc«/a» |"; 
echo "<a href-19-6.php?sort-" $rows2['sort ]."» 3$ 8J" $rows2['sort ]."«/a»|"; 
echo "<a href=19-7.php?id=".$rows2[id]."> 评 论 (".$rows2[tbcount].") «/a»|"; 
echo "<a href=19-7.php?id=".$rows2[id]."> 浏 览 〈".$rows2[views].") </a>"; 
echo "<hr width=\"100\">"; 
) 
echo "</td>"; 
echo "</tr>"; 


// 如 果 没 有 任何 参数 


$sql="select id from Stable log where p_id=0"; // 显 示 所 有 日 志 
Sresult=mysql_query($sql,$link); 


$msg_count=mysql_num_rows($result); /总 条 数 
$p count-ceil($msg count/10); /| 总 页 数 
echo "<tr>"; 

echo "<td bgcolor=\"#eeeefh"> 全 部 日 志 </td>"; 

echo "</tr>"; 

echo "<tr>"; 


echo "<td bgcolor=\"#eeeeff\">"; 

if($ GET[page]--0 && !$ GET[page]) 
$page-1; 

else 

$page-$ GET[pageT. 
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69 $s=($page-1)*10+1; 

70 $s=$s-1; 

71 $sql="select * from $table log where p id-0 order by id desc limit $s, 10"; 
72 $result=mysql_query($sql,$link); 

73 $nums-mysql num rows($result); 

74 if($nums<1) echo "还 没有 任何 日 志 记录 ! "， ”// 没 有 日 志 时 显示 的 信息 
75 else // 如 果 有 日 志 

76 { 

77 while($tows-mysq| fetch array($result)) /循环 显示 日 志 内 容 

78 { 

79 echo "<a hrefz19-7.php?id-" $rows['id]."»" $rows[title]."«/a»"; 
80 echo "<p>"; 

81 echo $rows[date; 

82 echo "<p>"; 

83 echo $rows['content"]; 

84 echo "<p>"; 

85 echo "<a href-19-7.php?id-" $rows[id']."» iji & xc «/a»|"; 

86 echo "<a href=19-6.php?sort=".$rows['sort]."> 类 别 : ".$rows[sort]."«/a»|"; 
87 echo "<a href=19-7.php?id=".$rows['id1."> 评 论 (C'.$Srows[tbcount].") </a>| 
88 echo "<a href-19-7.php?id-" $rows[id']."»;/9$ (".Srows[views'.") </a>"; 
89 echo "<hr width=\"100%\">"; 

90 } 

91 } 

92 echo "</td>"; 

93 echo "</tr>"; 

94 } 

95 } 

96 else // 如 果 有 日 期 参数 

97 { 

98 $y-$ GET[yT // 获 取 年 

99 $m-$ GET[m]; // 获 取 月 

100 $d=$_GET[d']; // 获 取 日 

101 $date=$y." 年 ".$m." 月 ".$d." 日 "; // 代 入 新 的 变量 中 

102 echo "<tr>"; 

103 echo "<td bgcolor=\"#eeeefN\">".$date." 的 日 志 </td>"; 

104 echo "</tr>"; 

105 echo "<tr>"; 

106 echo "<td bgcolor=\"#eeeeff\">"; // 查 找 当天 的 日 志 

107 $sql="select * from $table log where date like '$date'and p_id=0"; 

108 $result-mysgl query($sql.Slink); 

109 $nums-mysql num rows(Sresult); /获取 当天 日 志 数 量 

110 if($nums«1) echo "当天 没有 任何 日 志 记 录 ! "5 // 如 果 不 存在 

111 else // 如 果 存 在 

112 { 

113 while($rows=mysql_fetch_array($result) /循环 显示 

114 

115 echo "<a href219-7.php?idz" $rows['id']."»" $rows['title']."«/a»"; 
116 echo "<p>"; 

117 echo $rowsf'date']; 

118 echo "<p>"; 

119 echo $rows[content ]; 
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120 echo "<p>"; 

121 echo "<a href-19-7.php?id-" $rows[id']."» ili: & X: «/a» |" 
122 echo "<a href-19-6.php?sort-" $rows[sort]."» 3 3]" $rows[sort]."«/a» |"; 
123 echo "<a href-19-7.php?id-" $rows[id'."»i*i€ (C'".$rows[tbcount].") «/a»]|"; 
124 echo "<a href-19-7.php?id-" $rows[id']."»39& (".$rows[views'].") </a>"; 
125 echo "<hr width=\"100\">"; 

126 } 

127 ) 

128 echo "</td>"; 

129 echo "</tr>"; 

130 } 

131 ifl($_GET[y]and$_GET[m]and$_GET[d])&&!($_GET[sort]) 

132 { /显示 分 页 链接 
133 echo "<tr>"; 

134 echo "<td bgcolor=\"#eeeeff\">"; 

135 $prev_page=$page-1; 

136 $nert page-$paget1; 

137 if ($page<=1){ 

138 echo "第 一 页 |"; 

139 } 

140 else( 

141 echo "<a href='$PATH_INFO?page=1'> 第 一 页 </a> |", 

142 ) 

143 if ($prev page«1)( 

144 echo" E—m |" 

145 } 

146 else( 

147 echo "<a href-'$PATH INFO?page-$prev page'».E—71«/a» |", 
148 ) 

149 if($next page»$p count)( 

150 echo "下 一 页 | "; 

151 } 

152 else( 

153 echo "<a href='$PATH_INFO?page=$next_page'> 下 一 页 </a> | "; 
154 ) 

155 if(S5page»-$p count 

156 echo "最 后 一 页 </p>"; 

157 ) 

158 else( 

159 echo "<a href='$PATH_INFO?page=$p_count> 最 后 一 页 </a></p>"; 
160 ) 

161 echo "</td>"; 

162 echo "</tr>"; 

163 } 

164 echo "</table>"; 

165 echo "</td>"; 

166 echo "</tr>"; 

167 echo "</table>"; 

168 ?> 


说 明 : 本 实例 中 多 次 用 到 的 方法 就 是 使 用 HTML 代 码 将 查询 出 的 内 容 进行 格式 化 。 
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查看 日 志 的 条 件 可 以 是 某 一 类 的 所 有 日 志 ， 也 可 以 是 某 一 天 所 写 的 所 有 日 志 。 
19.4.3 单条 日 志 详 细 信 息 页 面 的 创建 


FAI 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 19 章 \ 单 条 日 志 详细 信息 页 面 的 创建 .wmv 
19.4.2 小 节 创建 的 日 志 显示 页 面 ， 只 显示 相关 日 志 ， 并 不 显示 日 志 的 详细 情况 及 相关 的 评论 。 本 小 
节 来 创建 单条 日 志 详细 信息 的 页 面 。 该 页 面 不 仅 显 示 某 一 条 日 志 的 详细 信息 ， 而 且 还 显示 所 有 对 该 日 
志 的 评论 。 
【实例 19-7】 以 下 为 单条 日 志 详细 信息 页 面 代码 。 


实例 19-7: 单条 日 志 详细 信息 
源码 路 径 光盘 \ 源 文件 \19\19-7.php 


01 <?php 

02 require "19-3.php"; // 调 用 头 文件 

03 i$ POST[id) // 如 果 没有 评论 ID 输入 
04 { 

05 echo "<table width=\"80%\">"; 

06 echo "<tr>"; 

07 echo "<td width=\"20%\">"; 

08 require "19-4.php"; // 调 用 侧 边 文件 

09 echo "</td>"; 

10 echo "<td width=\"80%\">"; 

11 echo "<table cellpadding=\"1\" cellspacing=\"1\" width=\"100%\" align=\"center\" bgcolor=\"#000000\">"; 
12 require "19-1.php"; 

13 $linkzmysql connect(Shost,Suser,$pass); /连接 主机 

14 mysql select db($db name,Slink); /| 选择 库 

15 $sql="select * from Stable log where id-'$ GET[id]' order by id desc"; 

16 $result«mysql query($sql,Slink); /发 送 显示 某 一 条 日 志 的 SQL 请 求 
17 $rows-mysql fetch array($result,$link); /| 置 入 数组 

18 echo "<tr bgcolor=\"#ffffff\">"; 

19 echo "<td>"; 

20 echo "<h3>".$rows['title]."</h3>"; /显示 标题 

21 echo "</td>"; 

22 echo "</tr>"; 

23 echo "<tr bgcolor=\V#ffffff >” 

24 echo "<td>"; 

25 echo $rows| title"); /显示 标题 

26 echo "<p>"; 

27 echo $rows[date']; /显示 日 期 

28 echo "<p>"; 

29 echo $rows['content]; /显示 内 容 

30 echo "<p>"; 

31 echo "<a href=19-6.php?sort=".$rows['sort]."> 类 别 : ".$rows[sort]."«/a»|"; 

32 echo "评论 (".$rows[tbcount].") |"; /显示 评论 数 

33 echo "浏览 〈".$rows[views]") "; /显示 浏览 数 

34 echo "<hr width=\"100%\">"; 

B5 echo "以 下 为 评论 内 容 : <br>"; /显示 对 该 条 日 志 的 评论 
36 $sql2="select * from Stable log where p id-'$ GET[id]"; 
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Sresult2=mysql_query($sql2, $link); /发 送 SQL 请 求 
while($row2=mysql_fetch_array($result2,$link)) // 循 环 显示 评论 
i 

echo "标题 : "$row2['title]; /显示 评论 标题 

echo "<p>"; 

echo "日 期 : ".$row2[date]; /显示 评论 日 期 

echo "<p>"; 

echo "内 容 : ".$row2['content; /显示 评论 内 容 

echo "<hr width=\"80%\">"; 
} // 下 面 一 句 每 浏览 一 次 ， 浏 览 次 数 增加 1 
$sql="update $table log set views-views*1 where id-'$ GET[id]"; 
mysql query($sql.Slink); /发 送 自 增 1 的 SQL 请 求 
echo "</td>"; 
echo "</tr>"; 
echo "</table>"; 
echo "<p>"; 
echo "<table cellpadding=\"1\" cellspacing=\"1\" align=\"center\" bgcolor=\"#000000\">"; 
echo "<form action=19-7.php method=post>"; /以 下 为 添加 评论 的 表单 


echo "<tr bgcolor=\"#eeffee\"><td>"; 

echo "发 表 评论 : "; 

echo "<input type=hidden name=id value-".$rowsfid').">"; 
echo "<input type=hidden name=sort value=". $rows['sort].">"; 
echo "</td></tr>"; 

echo "<tr bgcolor=\"#eeffee\"><td>"; 

echo "题目 : «input type=text name=title>"; 

echo "</td></tr>"; 

echo "<tr bgcolor=\"#eeffee\"><td>"; 

echo "评论 内 容 : <br><textarea name=content rows=5 cols=40></textarea>"; 
echo "</td></tr>"; 

echo "<tr bgcolor=\"#eeffee\"><td>"; 

echo "<input type=submit value=\" 发 表 \">"; 

echo "</td></tr>"; 

echo "</form>"; 

echo "</table>"; 

echo "</td>"; 

echo "</tr>"; 

echo "</table>"; 


IAS FI PE SEVERE 


$id-$ POST[id]; // 获 取 各 项 参数 
$title-$ POSTT title; 
$sort-$ POST['sort]; 
$content-$ POST[content]; 
$date-$date-date("Y 4# n A d R"); 
if!$ COOKIE["username"]) /如 果 没 有 用 户 登录 
{ 
$username=" 匿 名 "; I RIP 


else 


t 
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88 $username=$_COOKIE["username"]; /登录 用 户 

89 } 

90 require "19-1.php"; // 调 用 配置 文件 
91 $link=mysql_connect($host,$user,$pass); 

92 mysql_select_db($db_name, $link); 

93 $sql="insert into $table log(p id, author, title, content, sort, date)values('$id','$username','$title', 
'$content'/'$sort','$date")"; 

94 mysql query($sql.Slink); /插入 评论 记录 
95 $sql="update $table log set tbcount=tbcount+1 where id-'Sid"; 

96 mysql query($sql.Slink); // 评 论 数 自 增 1 
97 echo "<meta http-equiv=\"refresh\" content=\"2; url=19-7?id=".$id.".php\">"; 
98 echo "</head>"; 

99 echo "<body>"; 

100 echo "添加 成 功 评论 ， 正 在 返回 "; 

101 echo "</body>"; 

102 echo "</html>"; 

103 

104 ?> 


说 明 : 本 实例 的 核心 就 是 通过 判断 日 志 ID 来 从 数据 库 中 查询 信息 并 显示 。 


单 击 某 一 条 日 志 的 标题 ， 或 者 单 击 “ 阅 读 全 文 ”链接 ， 均 可 以 进入 查看 该 条 日 志 详情 的 页 面 ， 相 
当 于 执行 19-7.php。 


19.5 管理 模块 


本 节 来 创建 管理 模块 ， 管 理 模 块 不 仅 包括 日 志 的 管理 ， 还 包括 用 户 信 息 的 管理 、 留 言 管理 、 注 册 
用 户 管理 等 内 容 。 用 户 管理 使 每 个 用 户 可 以 修改 自己 的 注册 信息 ， 而 日 志 管理 、 留 言 管理 、 所 有 注册 
用 户 的 管理 则 属于 管理 员 特 有 的 权限 。 下 面 就 为 读者 一 一 说 明 。 


19.51 管理 员 / 用 户 登 录 页 面 


Gl 知识 点 讲解 : 光盘 \ 视 频 讲 解 \ 第 19 章 \ 管 理 员 /用 户 登 录 页 面 .wmv 

本 小 节 来 创建 用 户 登录 页 ， 用 户 包括 普通 用 户 与 管理 员 。 管 理 员 登 录 以 后 ， 可 以 对 博客 的 整体 情 
况 进行 全 面 的 管理 ， 如 签 写 日 志 、 分 类 管理 、 日 志 管 理 等 内 容 。 普 通用 户 登 录 之 后 则 可 以 行使 匿名 用 
户 所 不 具有 的 权限 ， 例 如， 对 日 志 发 表 评 论 、 浏 览 匿名 用 户 不 能 浏览 的 日 志 等 。 同 时 不 管 何 种 用 户 都 
可 以 更 改 本 用 户 注册 的 各 项 信息 。 

【实例 19-8】 以 下 为 管理 员 /用 户 登录 页 面 代码 。 


区 实例 19-8: 管理 员 / 用 户 登录 
源码 路 径 : 光盘 \ 源 文件 \19\19-8.php 


01 <?php 
02 ifl$ POST[username]) 
03 { 


else 
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require "19-3.php"; // 调 用 头 文件 

echo "<script language- "javascript "7"; 

echo "function juge(theForm)"; 

echo "("; 

echo "if (theForm.username.value == \"\")"; 

echo "("; 

echo "alert(\ 请 输入 用 户 名 ! Vy" 

echo "theForm.admin.focus();"; 

echo "return (false);"; 

echo "}"; 

echo "if (theForm.password.value == V") 

echo "f"; 

echo "alert(\" 请 输入 密码 ! \");"; 

echo "theForm.pass.focus();"; 

echo "return (false);"; 

echo "}"; 

echo "}"; 

echo "</script>"; 

echo "<center>"; 

echo "<table cellpadding- 1! cellspacing=\"1\" align=\"center\" bgcolor=\"#000000\" width 8096": 
echo "<form method=\"post\" actionz'$PATH INFO" onsubmit=\"return juge(this)V'»"; 
echo "<tr bgcolor=\"#cccc99\">"; 

echo "<td colspan=\"2\" align=\"center\"> 管 理 员 /用 户 登录 </td>"; 

echo "</tr>"; 

echo "<tr bgcolor=\"#cccc99\">"; 

echo "<td> 输 入 用 户 名 </td>"; 

echo "<td><input type=\"text\" name=\"username\"></td>"; 

echo "</tr>"; 

echo "<tr bgcolor=\"#cccc99\">"; 

echo "<td> 输 入 密码 :</td>"; 

echo "<td><input type=\"password\" name=\"password\" size=\"21\"></td>"; 
echo "</tr>"; 

echo "<tr bgcolor=\"#cccc99\">"; 

echo "<td colspan=\"2\"><center><input type=\"submit\" value=\" 登 录 \"></center></td>"; 
echo "</tr>"; 

echo "</form>"; 

echo "</table>"; 

echo "</center>"; 

echo "</body>"; 

echo "<html>"; 


$username=$_POST[username']; // 获 取 用 户 名 
$password=md5($_POST[password]'); /获取 密码 ， 并 用 MD5 加 密 
require "19-1.php"; // 调 用 配置 文件 
$link=mysql_connect($host,$user,$pass); /连接 主机 

mysql select db($db name,Slink); /选择 数据 库 


$sql="select * from $table user where username='$username' and password='$password"'; 
S$result-mysql query($sql.Slink) or die(mysql error()); 
$row-mysql| num rows(Sresult); // 获 取 符 合 的 用 户 数量 
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if(Srow«1) // 如 果 符合 的 数量 为 0 


require "19-3.php"; // 调 用 头 文件 
echo "<meta http-equiv=\"refresh\" content=\"2; url=19-8.php\">"; 
echo "用 户 名 或 者 密码 错误 两 秒 后 返回 ! "; // 显 示 错 误 信息 


/如果 存 在 符合 条 件 的 用 户 
setcookie("username", $username); 1 注册 Cookie 
require "19-3.php"; // 调 用 头 文 件 
echo "<table width=\"80%\">"; 
echo "<tr>"; 
echo "<td width=\"20%\">"; 
$rows=mysql_fetch_array($result); /用 户 信息 置 入 数组 


echo "<table cellpadding=\"1\" cellspacingz V1 align=\"center\" bgcolor=\"#000000\">"; 
echo "<tr>"; 
echo "<td bgcolor=\"#ffeeee\">"; 
echo "<a href=\"19-9.php\" target=\"fram\"> 用 户 信息 </a>"; 
echo "</td>"; 
echo "</tr>"; 
echo "<tr>"; 
echo "<td bgcolor=\"#eeffee\">"; 
echo "<a href=\"19-10.php\" target=\"fram\"> 更 改 密码 </a>"; 
echo "</td>"; 
echo "</tr>"; 
if(Srowsl'admin']--^1") // 如 果 用 户 为 管理 员 显示 更 多 操作 
f 
echo "<tr>"; 
echo "<td bgcolor=\"#eeffee\"><a href=19-11.php target=\"fram\"> 分 类 管理 </a></td>"; 
echo "</tr>", 
echo "<tr>"; 
echo "<td bgcolor=\"#eeffee\"><a href=19-16.php target=\"fram\"> 添 加 分 类 </a></td>"; 
echo "</tr>"; 
echo "<tr>"; 
echo "<td bgcolor=\"#eeffee\"><a href=19-12.php target=\"fram\"> 发 表 日 志 </a></td>"; 
echo "</tr>"; 
echo "<tr>"; 
echo "<td bgcolor=\"#eeffee\"><a href=19-13.php target=\"fram\"> 日 志 管 理 </a></td>"; 
echo "</tr>"; 
echo "<tr>"; 
echo "<td bgcolor=\"#eeffee\"><a href-19-14.php target=\"fram\"> 留 言 管 理 </a></td>"; 
echo "</tr>"; 
echo "<tr>"; 
echo "<td bgcolor=\"#eeffee\"><a hrefz19-15.php target=\"fram\"> 用 户 管理 </a></td>"; 
echo "</tr>"; 
) 
echo "</table>"; 
echo "</td>"; 
echo "<td width=\"80%\">"; 
echo "<iframe name=\"fram\" src=\"19-9.php\" width=\"476\" height=\"350\" frameBorder=\"0\">"; 
echo "</td>"; 


echo "</tr>"; 
echo "</table>"; 


注意 : 管理 员 与 用 户 应 该 有 不 同 的 权限 。 

现在 就 可 以 用 管理 员 的 身份 登录 该 页 ， 以 便 执行 管理 分 类 、 添 加 分 类 、 签 写 日 志 、 管 理 日 志 、 管 
理 留言 、 管 理 用 户 等 操作 。 

首次 执行 19-8.php， 执 行 结 果 如 图 19.4 所 示 。 


(OCE 


Mic v 


图 19.4 管理 /用 户 登录 页 执行 结果 


19.5.9 更改 用 户 注 册 信 息 


CA 知识 点 讲解 ， 光 盘 \ 视 频 讲解 \ 第 19 章 \ 更 改 用 户 注册 信息 .wmv 
无 论 是 管理 员 或 者 是 普通 注册 用 户 都 有 权 更 改 已 经 注册 的 本 用 户 信 息 ， 本 小 节 就 来 创建 更 改 注册 


用 户 信 


息 的 页 面 。 


【实例 19-9】 以 下 为 更 改 用 户 注册 信息 的 代码 。 


<?php 


实例 19-9: 更 改 用 户 注册 信息 
源码 路 径 : 光盘 \ 源 文件 \19\19-9.php 


if(!$_COOKIE[username') // 如 果 没有 登录 用 户 


"没有 用 户 登录 !"; 


} 


else 


if(l$ POST[nickname']) // 如 果 没 有 发 送 表单 变量 ， 则 显示 HTML 


{ 


echo "<html>"; 

echo "<head>"; 

echo "<title> 博 客 程序 
echo "</head>"; 
echo "<body>"; 

echo "<script language=\"javascript\">"; 
echo "function juge(theForm)"; 


显示 登录 用 户 信息 </title>"; 
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dui 
18 
19 
20 
21 
22 
23 
24 
25 
26 
27 
28 
29 


35 
\"#000000\">"; 
36 
37 
38 
39 
40 
41 
42 
43 
44 
45 
46 
47 
48 
49 
50 
51 
52 


echo "f"; 

echo "if (theForm.nickname.value == \"\")"; 

echo "("; 

echo "alert(\" 匿 称 必须 要 填 !\");"; 

echo "theForm.nickname.focus();"; 

echo "return (false);": 

echo "j^; 

echo "j^ 

echo "</script>"; 

require "19-1.php"; 

Slinkzmysql connect(Shost,Suser,$pass); 

mysql select db($db name,Slink); 

$sql-"select * from $table user where username-'$ COOKIE[username]"; 
Sresult-mysql query($sql,Slink); 

$rows-mysq|l fetch array(Sresult); /登录 用 户 信息 置 入 数组 
echo "<center>"; 

echo "<h1> 下 面 显示 登录 用 户 信息 </h1>"; 

echo "<h3> 如 果 需 要 更 改 用 户 信息 ， 直 接 更 改 即 可 </h3>"; 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\" align=\"center\" bgcolor= 


echo "<form action=19-9.php method=post onsubmit=\"return juge(this)\">"; 
echo "<tr>"; 

echo "<td bgcolor=V#ffffff"> 昵 称 </td>"; 

echo "<td bgcolor=\"#ffffff\"><input type=\"text\" name=\"nickname\" value=\""; 
echo $rows['nicknameT; 

echo "\" ></td>"; 

echo "</tr>"; 

echo "<tr>"; 

echo "<td bgcolor=\"#fffffN"> ERI </td>"; 

echo "<td bgcolor=\"#fffffA">"; 

echo "<input type=radio name=sex value-boy "; 

if(Srows[sex']--7"boy") echo "checked"; 

echo " »boy"; 

echo "<input type=radio name-sex value-girl "; 

if($rows[sex']--"girl") echo "checked"; 

echo " »girl"; 

echo "</td>"; 

echo "</tr>"; 

echo "<tr>"; 

echo "<td bgcolor=\"#fffff"> 重 新 输入 图 像 </td>"; 

echo "<td bgcolor-V'ffffff'» «input type=\"text\" name=\"photo\" value=\""; 
echo "\" ></td>"; 

echo "</tr>"; 

echo "<tr>"; 

echo "<td bgcolor=\"#ffffff\">Email</td>"; 

echo "<td bgcolor=\"#ffffff\"><input type=\"text\" name=\"email\" value=\""; 
echo $rows['email'; 

echo "\" ></td>"; 

echo "</tr>"; 
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65 echo "<tr>"; 

66 echo "<td bgcolor=V#ffffff"> 个 人 宣言 </td>"; 

67 echo "<td bgcolor=\V#ffffff > 

68 echo "«textarea name=\"description\">". $rows['description']."</textarea>"; 
69 echo "</td>"; 

70 echo "</tr>"; 

71 echo "<tr>"; 

72 echo "<td bgcolor=\"#fffff\" colspan- V2» «center» «input type=submit value=\" 确 认 修 改 
\"></center></td>"; 

TS echo "</tr>"; 

74 echo "</form>"; 

5 echo "</table>"; 

76 } 

Uti else // 如 果 发 送 表 单 

78 ( 

79 $nickname-$ POST[nicknameT; [3E 3 bu 1 

80 $sex-$ POST[sex]; 

81 $photo-$ POST[photo; 

82 S$email-$ POST[email; 

83 S$description-$ POST[description'; 

84 require("19-1.php"); 

85 S$linkzmysql connect($host,Suser,$pass); 

86 mysql select db($db name,Slink); 

87 $sql-"update $table user set nickname-'$nickname',sex-'$sex' photo-'$photo',email- 
'$email' description-'$description' where username-'$ COOKIE[username]"; 

88 $result-mysql query($sql,Slink); /发 送 修改 表 内 容 的 SQL 请 求 
89 echo "<html>"; 

90 echo "<head>"; 

91 echo "<title> 博 客 程序 一 一 用 户 登录 </title>"; 

92 echo "<meta http-equiv=\"refresh\" content=\"2; url=19-9.php\">"; 

93 echo "</head>"; 

94 echo "<body>"; 

95 echo "用 户 信息 更 改 成 功 ! 两 秒 后 返回 "; 

96 echo "</body>"; 

87 echo "</html>"; 

98 y 

99 } 

100 ?> 


注意 : 因为 该 页 面 是 以 框架 形式 包含 在 实例 19-8 中 的 ， 所 以 应 该 首先 执行 实例 19-8， 然 后 就 可 以 更 改 用 
户 昵 称 、 性 别 、 电 子 信箱 、 个 人 宣言 等 信息 。 


需要 注意 的 是 ， 管 理 员 的 个 人 信息 将 显示 在 首页 。 在 这 里 ， 把 管理 员 的 昵称 由 TomCat 改 为 CAT, 
个 人 宣言 改 为 HELLO WORLD! 以 查看 实例 19-9 的 执行 结果 。 进 行 相应 修改 并 单 击 “ 确 认 修 改 ” 按钮 
之 后 ， 执 行 结 果 如 图 19.5 所 示 。 

在 执行 过 这 一 步 的 操作 之 后 ， 单 击 最 上 面 的 “首页 ”链接 ， 回 到 首页 将 会 看 到 显示 管理 员 信息 的 
区 域 已 经 显示 了 新 的 信息 。 
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19.5 更 改过 用 户 信息 之 后 的 执行 结果 
19.5.3 更改 注册 用 户 密码 页 面 


RE 知识 点 讲解 :光盘 \ 视 频 讲 解 \ 第 19 章 \ 更 改 注册 用 户 密码 页 面 .wmv 

因为 用 户 密码 关系 着 用 户 账号 的 安全 ， 所 以 不 能 跟 用 户 其 他 信息 一 样 ， 而 是 要 单独 修改 ， 这 样 可 
以 保护 密码 的 安全 ， 并 且 密 码 都 是 把 用 户 的 输入 经 过 了 MD5 加 密 的 ， 就 算得 到 了 明码 ， 也 不 会 知道 密 
码 的 内 容 。 

【实例 19-10】 以 下 为 更 改 注册 用 户 密码 页 面 代码 。 


实例 19-10: 更 改 注册 用 户 密码 
源码 路 径 : 光盘 \ 源 文件 \19\19-10.php 


01 <?php 

02 error reporting(0); 

03 if!$ COOKIE[username]) // 如 果 没 有 登录 用 户 ， 显 示 信息 
04 { 

05 "没有 用 户 登录 !"; 

06 } 

07 else // 如 果 用 户 已 经 登录 
08 { 

09 if(IS POST[old pass) // 如 果 没 有 表单 发 送 ， 显 示 HTML 
10 { 

11 echo "<html>"; 

12 echo "<head>"; 

13 echo "<title> 博 客 程序 一 一 更 改 登录 用 户 密码 </title>"; 

14 echo "</head>"; 

15 echo "<body>"; 

16 echo "<script language=\"javascript\">"; 

ri echo "function juge(theForm)"; 

18 echo "{"; 

19 echo "if (theForm.old pass.value == VY)"; 

20 echo "{"; 

21 echo "alert(\" 请 输入 原始 密码 ! Vy" 


36 
37 
38 
39 
40 
41 
42 
43 
44 
45 
46 
4T 
\"#000000\">"; 
48 
49 
50 


65 
\"></center></td>"; 
66 
67 
68 
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echo "theForm.old pass.focus();"; 

echo "return (false);": 

echo "j^ 

echo "if (theForm.new pass.value == \"\")"; 
echo "{"; 

echo "alert(\" 请 输入 新 密码 ! Vy". 

echo "theForm.new pass.focus();"; 

echo "return (false);": 

echo ")"; 

echo "if (theForm.new. pass.value.length < 8 )"; 
echo "(*; 

echo "alert(\" 密 码 至 少 要 8 fir! Vy" 

echo "theForm.new pass.focus();"; 

echo "return (false);"; 

echo "}"; 

echo "if (theForm.re pass.value !-theForm.new pass.value)"; 
echo T: 

echo "alert(\" 确 认 密码 与 密码 不 一 致 !\");"; 
echo "theForm.re pass.focus();"; 

echo "return (false);"; 

echo "|", 

echo "}"; 

echo "</script>"; 

echo "<center>"; 

echo "<h3> 输 入 原始 密码 及 新 密码 </h3>"; 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\" align=\"center\" bgcolor= 


echo "<form action=19-10.php method=post onsubmit=\"return juge(this)\">"; 

echo "<tr>"; 

echo "<td bgcolor=V#ffffff"> 原 始 密码 : </td>"; 

echo "<td bgcolor=V#ffffff"><input type=\"password\" name=\"old_pass\" value=\""; 
echo "\" ></td>"; 

echo "</tr>"; 

echo "<tr>"; 

echo "<td bgcolor=V#ffffff"> 新 密码 : </td>"; 

echo "<td bgcolor=\"#ffffff\"><input type=\"password\" name=\"new_pass\" value=\""; 
echo "\" ></td>"; 

echo "</tr>"; 

echo "<tr>"; 

echo "<td bgcolor=V#ffffff"> 确 认 新 密码 : </td>"; 

echo "<td bgcolor=\V#ffffff ><input type=\"password\" namez-l're pass" value=\""; 
echo "" ></td>"; 

echo "</tr>"; 

echo "<tr>"; 

echo "<td bgcolor=\"#fffffì\" colspan=\"2\"><center><input type=submit value=\" 确 认 修改 


echo "</tr>"; 


echo "</form>"; 
echo "</table>"; 
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69 ) 

70 else // 如 果 发 送 表 单 变 量 

71 { 

72 $old_pass=md5($_POST['old_pass]): // 获 取 表 单 变 量 

73 $new pass-$ POST[new pass]; 

74 require "19-1.php"; 

75 Slink-mysql connect(Shost,Suser,$pass); 

76 mysql select db(Sdb name,Slink); 

TT S$sql-"select * from $table user where username-'$ COOKIE[username] and password 
-'$old pass"; 

78 $reslut-mysql query($sql,Slink); /发 送 验证 用 户 身份 的 SQL 请 求 
79 $row=mysql_num_rows($result); /符合 条 件 的 记录 数 

80 if(Srow«1) // 如 果 不 存在 符合 条 件 的 记录 ， 显 示 信 息 
81 

82 echo "«html»"; 

83 echo "<head>"; 

84 echo "<title> 博 客 程序 一 一 用 户 登录 </title>"; 

85 echo "<meta http-equiv=\"refresh\" content=\"2; url=19-10.php\">"; 

86 echo "</head>"; 

87 echo "<body>"; 

88 echo "输入 的 密码 错误 ! 或 者 用 户 不 存在 ! MHR AE!" 

89 echo "</body>"; 

90 echo "</html>"; 

91 ) 

92 else // 如 果 旧 密码 正确 

93 { 

94 $sql="update $table user set password-'$new pass' where username-'$ COOKIE 
[username] and password-'$old pass"; 

95 $result-mysql query($sql.Slink); /发 送 更 改 旧 密码 为 新 密码 的 SQL 请求 
96 echo "<html>"; 

97 echo "<head>"; 

98 echo "<title> 博 客 程序 一 一 用 户 登录 </title>"; 

99 echo "<meta http-equiv=\"refresh\" content=\"2; url=19-10.php\">"; 

100 echo "</head>"; 

101 echo "<body>"; 

102 echo "更 改 成 功 ! 以 后 请 使 用 新 密码 登录 !"; 

103 echo "</body>"; 

104 echo "</html>"; 

105 ) 

106 ) 

107 

108 ?> 


注意 : 当前 互联 网 中 修改 密码 通常 会 经 过 很 多 验证 。 
同 实例 19-9 一 样 ， 该 页 面 也 是 以 框架 形式 包含 在 实例 19-8 的 代码 中 。 由 于 修改 密码 操作 与 修改 用 
户 信息 操作 基本 类 似 ， 这 里 就 不 再 给 执行 结果 图 了 。 
户 信息 更 改 及 用 户 密码 更 改 是 所 有 用 户 都 拥有 的 权限 。 下 面 几 节 的 操作 就 是 只 有 管理 员 才 有 的 
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权限 ， 如 日 志 管 理 、 分 类 管理 、 留 言 管 户 管理 等 。 从 19.5.4 小 节 开始 来 分 别 创建 这 些 页 面 。 
19.5.4 修改 已 经 存在 的 日 志 类 别 


"i 知识 点 讲解 : EAA 19 章 \ 修 改 已 经 存在 的 日 志 类 别 .wmv 
志 的 类 别 是 日 志 的 一 个 重要 属性 ， 所 以 对 类 别 的 管理 也 很 重要 。 本 小 节 来 创建 类 别管 理 的 页 面 。 
es 一 样 ， pe 理 员 才 有 的 超级 权限 ， 所 以 在 用 户 调用 该 页 时 要 对 用 户 的 身份 
进行 判断 。 
【实例 19-11】 以 下 为 修改 已 经 存在 日 志 类 别 的 代码 。 


实例 19-11; 修改 已 经 存在 日 志 类 别 
源码 路 径 光盘 \ 源 文件 \19\19-11.php 


01 <?php 

02 if($_COOKIE['username') // 如 果 用 户 已 经 登录 

03 ( 

04 require "19-1.php"; // 调 用 配置 文件 

05 $link=mysql_connect($host,$user,$pass); 

06 mysql select db($db name,Slink); 

07 $sgl-"select * from Stable user where username-'$ COOKIE[username]":; 

08 $result-mysql query($sql,Slink); // 发 送 获取 用 户 信息 的 SQL 请 求 

09 $row-mysq| fetch, array(Sresult); /用 户 信息 置 入 数组 

10 if ($row['admin']=="1") // 如 果 用 户 为 管理 员 ， 则 执行 以 下 操作 

11 ( 

12 if($ POST[action']) // 如 果 没 有 发 送 表 单 变量 ， 显 示 HTML 

13 

14 echo "<center>"; 

15 echo "<h3> 修 改 类 别 </h3>"; 

16 echo "<table cellpadding=\"1\" cellspacing=\"1\" align=\"center\" bgcolor=\"#000000\" 
width=\"100%\">"; 

17 echo "<form method=\"post\" action-'$PATH. INFOY'»"; 

18 $sql-"select * from Stable sort"; /显示 所 有 已 经 存在 的 类 别 

19 Sresult=mysql_query($sql,$link); // 发 送 SQL 请 求 

20 echo "<tr>"; 

21 echo "<td bgcolor=\"#ccffcc\"> 类 名 </td><td bgcolor=\"#ccffcc\"> 类 说 明 </td><td 
bgcolor=\"#ccffcc\"> 操 作 类 型 </td>"; 

22 echo "</tr>"; 

23 while($rows=mysql_fetch_array($result)) /循环 显示 所 有 类 

24 t 

25 echo "<tr>"; 

26 echo "<input type=hidden namecid[$i] value-" $rows[id]."»"; 

27 echo "<input type=hidden name=o_sort[$i] value=".$rows[sortname].">"; 

28 echo "<td bgcolor=\"#eeeeff\"><input type=text value=".$rows[sortname]." 


name=sortname[$i]></td><td bgcolor=\"#eeeeff\"><textarea name=description[$i] rows=3 cols=20>".$rows 
['description']."</textarea></td>"; 


29 echo "<td bgcolor=\"#eeeeff\"><input type=radio name=action[$i] value=del 
checked» llli «br» «input type=radio name=action[$i] value-edit» f£ z& «br» «/td»": 

30 echo "</tr>"; 

31 $i++; 
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61 
where id-'$temp1"; 
62 
63 
64 
65 
66 
67 
68 
69 
70 
71 
72 
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else 


) 

echo "<tr>"; 

echo "<td colspanz "3" bgcolor=\"#eeffee\"><center>"; 
echo "<input type=submit value=\" 确 认 提 交 \">"; 

echo "</center></td>"; 

echo "</form>"; 

echo "</table>"; 

echo "</center>"; 

echo "</body>"; 

echo "<html>"; 


// 如 果 发 送 表单 变量 ， 则 执行 操作 
require "19-1.php"; // 调 用 配置 文件 
Slink=mysql_connect($host,$user,$pass); /连接 MySQL 主机 
mysql_select_db($db_name, $link); /| 选择 数据 库 


for($i=0;$i<count($_POSTŢ'id']);$i++) // 根 据 操作 类 型 循环 执行 操作 
{ 
Stemp1=$_POST[id1[$i; // 循 环 获取 表单 变量 
Stemp2=$_POST[sortname'[$i]: 
$temp3=$_POST['description'][$i]; 
$temp4=$_POST['o_sort'][$i]; 
if($ POST[action'][$i]--"del") // 如 果 操 作 类 型 为 删除 
{ 
$sql="delete from $table sort where id-'$temp1""; 
$sql2-"delete from $table log where sort-'$temp2"; 
) 
else // 如 果 操 作 类 型 为 修改 


{ 


$sql="update $table_sort set sortname-'$temp2',description-'$temp3' 


$sql2="update $table log set sort='$temp2' where sort='$temp4"; 
) 


mysql query($sql); // 发 送 对 类 的 相关 操作 的 SQL 请 求 
mysql query($sql2); /发 送 对 日 志 相关 操作 的 SQL 请 求 
echo "<html>"; 
echo "<head>"; 
echo "<title> 博 客 程序 </title>"; 


echo "<meta http-equiv=\"refresh\" content=\"2; url=19-11.php\">"; 
echo "</head>"; 

echo "<body>"; 

echo "处 理 成 功 ， 正 在 返回 "; 

echo "</body>"; 

echo "</html>"; 


// 如 果 用 户 不 是 管理 员 


echo "普通 用 户 没有 该 权限 人"; /显示 信息 
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83 else // 如 果 用 户 没有 登录 
84 { 

85 echo "你 还 没有 登录 ,点 <a href=19-8.php> 这 里 </a> 进 行 登录 !"; 

86 } 

87 ?» 


注意 : 修改 日 志 类 别 是 管理 员 的 权限 。 
户 以 管理 员 身 份 登录 系统 ， 并 执行 该 操作 时 ， 执 行 结果 如 图 19.6 所 示 。 
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图 19.6 分 类 管理 执行 结果 
由 于 我 们 还 没有 为 博客 添加 其 他 类 别 ， 因 此 这 里 只 显示 默认 类 别 。 


19.5.5 ” 签 写 新 的 日 志 页 面 


YA 知 识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 19 章 \ 签 写 新 的 日 志 页 面 .wmv 

由 于 刚 建成 的 系统 中 并 没有 任何 日 志 ， 而 博客 程序 必须 要 使 管理 员 具 有 写 日 志 这 项 权限 才 行 ， 这 
是 最 基本 的 功能 ， 所 以 本 小 节 来 创建 管理 员 签 写 新 日 志 的 页 面 。 

【实例 19-12】 以 下 为 签 写 新 日 志 页 面 的 代码 。 


Ki v 


01 <?php 

02 error reporting(0); 

03 i$ COOKIE[username7) /如 果 用 户 已 经 登录 

04 { 

05 require "19-1.php"; // 调 用 配置 文件 

06 Slinkzmysql connect(Shost,Suser.$pass); /连接 主机 

07 mysql_select_db($db_name, $link); /| 选择 数据 库 

08 $sql="select * from $table user where username-'$ COOKIE[username]": 

09 $result-mysql query($sql.Slink); // 发 送 获取 用 户 信息 的 SQL 请 求 
10 $row-mysq| fetch array(Sresult); /用 户 信息 置 入 数组 

11 if (Srowl'admin']--"1") // 如 果 用 户 为 管理 员 执行 以 下 操作 


” ”PHP 网 络 编程 技术 详解 


12 { 
13 ifl$ POST[content]) // 如 果 没 有 发 送 表单 变量 ， 则 显示 HTML 
14 n 

15 echo "<script language-'javascriptV"» "; 

16 echo "function juge(theForm)"; 

T echo "("; 

18 echo "if (theForm.title. value == \"\")"; 

19 echo "("; 

20 echo "alert(\" 请 输入 日 志 标题 !\");"; 

21 echo "theForm .title.focus();"; 

22 echo "return (false);"; 

23 echo ")"; 

24 echo "if (theForm.content.value == V") 

25 echo "{"; 

26 echo "alert(\" 请 输入 日 志 内 容 ! \");"; 

27 echo "theForm.content.focus();"; 

28 echo "return (false);"; 

29 echo "j^: 

30 echo "^; 

31 echo "</script>"; 

32 echo "<center>"; 

33 echo "<table cellpadding=\"1\" cellspacing=\"1\" alignzV'center" bgcolor=\"#000000\" 
width=\"100%\">"; 

34 echo "<form method=\"post\" action=\"$PATH_INFOV" onsubmit=\"return juge(this)\">"; 
35 echo "<tr bgcolor=\"#cccc99\">"; 

36 echo "<td colspan=\"2\" align=\"center\"> 签 写 新 的 日 志 </td>"; 

37 echo "</tr>"; 

38 echo "<tr bgcolor=\"#cccc99\">"; 

39 echo "<td> A ÆRE </td>"; 

40 echo "<td><input type=\"text\" name=\"title\"></td>"; 

41 echo "«/tr»"; 

42 echo "<tr bgcolor=\"#cccc99\">"; 

43 echo "<td> 所 属 类 别 </td>"; 

44 echo "<td><select name=\"sort\" size=\"1\">"; 

45 $sql="select sortname from $table sort"; 

46 $result-mysgl query($sql,Slink); 

47 while($rowszmysql fetch array($result)) 

48 { 

49 echo "<option value=\""; 

50 echo $rows[0]; 

51 echo \">", 

52 echo $rows[0]; 

53 ) // 通 过 循环 显示 所 有 存在 类 别 
54 echo "«/select» «/td»": 

55 echo "</tr>"; 

56 echo "<tr bgcolor=\"#cccc99\">"; 

57 echo "<td> 日 志 内 容 : </td>"; 

58 echo "«td» «textarea rows-z 10V" cols=\"40\" name=\V content V" «/textarea? «/td»": 
59 echo "</tr>"; 

60 echo "<tr bgcolor=\"#cccc99\">"; 

61 echo "<td> 是 否 可 见 : </td>"; 
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echo "<td><input type=radio name=\"hide\" value=n checked> 是 <input type=radio 


name=\"hide\" value=y> 否 </td>"; 


63 
64 
65 


</center></td>"; 


66 
67 
68 
69 
70 
71 
72 
73 
74 
75 
76 
77 
78 
79 
80 
81 
82 
83 


echo "</tr>"; 
echo "<tr bgcolor=\"#cccc99\">"; 
echo "<td colspan=\"2\"><center><input type=\"submit value=\" 确认 1g 3 V» 


echo "</tr>"; 
echo "</form>"; 
echo "</table>"; 
echo "</center>"; 
echo "</body>"; 
echo "<html>"; 


/如果 发 送 表单 变量 ， 则 执行 操作 


$title-$ POSTT title"), // 获 取 表 单 变量 
$content=$_POST[content]; 

S$hide-$ POST[hide; 

$sort-$ POST[sort]; 

$date-date("Y *£ n A d A"); // 获 取 当 前 日 期 

require "19-1.php"; 

Slinkzmysql connect(Shost,Suser,$pass); 

mysql select db($db name,Slink); 

$sql-"insert into Stable log(title,content,sort,author,hide,date)values('$title''$content', 


'$sort''$ COOKIE[username]','Shide' '$date")" 


84 
85 
86 
87 
88 


100 
101 
102 
103 
104 
105 
106 


107 ?> 


) 


else 


mysql query($sql,Slink); /发 送 插入 新 日 志 记录 的 SQL 请 求 
$sql2="update $table sort set sortnum=sortnum+1 where sortname-'$sort""; 
mysql_query($sql2,$link); /发 送 更 改 类 别 数量 的 SQL 请 求 
echo "<html>"; 

echo "<head>"; 

echo "<title> 博 客 程序 </title>"; 


echo "<meta http-equiv=\"refresh\" content=\"2; url=19-12.php\">"; 
echo "</head>"; 


echo "<body>"; 
echo "添加 成 功 ， 正 在 返回 "; 
echo "</body>"; 
echo "</html>"; 
// 如 果 用 户 不 是 管理 员 
echo "iii Ri Pus Sid RIS 
// 如 果 没 有 登录 用 户 


echo "你 还 没有 登录 ,点 <a href=19-8.php> 这 里 </a> 进 行 登录 !"; 


说 明 : 本 实例 的 重点 就 是 将 用 户 输入 的 信息 写 入 数据 库 。 
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当 以 管理 员 身 份 登录 系统 以 后 ， 就 可 以 调用 该 页 面 来 写 新 的 日 志 ， 或 者 叫 “ 写 博客 ”了 。 管 理 员 
登录 之 后 ， 应 该 能 够 签 写 新 的 日 志 。 单 击 左 侧 边 的 “发 表 日 志 ” 链 接 ， 相 当 于 执行 实例 19-12， 执 行 结 
果 如 图 19.7 所 示 。 
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图 19.7 签 写 新 的 日 志 执行 结果 
为 了 方便 以 后 测试 ， 这 里 可 以 输入 儿 条 以 作为 测试 之 用 。 
日 志 标题 输入 “第 一 篇 PHP Hos", 日 志 内 容 随便 填写 一 些 内 容 以 作为 测试 ， 然 后 可 以 再 输入 一 
条 “JavaScript 日 志 ” 的 记录 。 


发 表 日 志 之 后 ， 当 时 发 现 不 了 结果 ， 因 为 操作 成 功 之 后 都 又 跳 转 到 了 签 写 新 日 志 页 。 不 过 通过 下 
面 的 操作 就 能 看 到 所 写 的 日 志 了 。 


19.5.6 已 经 存在 的 日 志 管 理 页 


YA 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 19 章 \ 已 经 存在 的 日 志 管 理 页 .wmv 

写 过 的 日 志 ， 有 时 需要 进行 修改 ， 另 外 觉得 没有 用 的 日 志 也 要 进行 删除 。 所 有 这 些 操作 都 要 有 管 
理 权 限 的 管理 员 才能 进行 ， 本 小 节 pit 管理 页 。 

【实例 19-13】 以 下 为 已 经 存在 的 日 志 管 理 页 代码 。 


区 O | “实例 19-13: 已 经 存在 的 日 志 管理 页 
源码 路 径 光盘 \ 源 文件 \19\19-13.php 


01 <?php 

02 if$_COOKIE[username]) 1/ 如 果 没有 登录 用 户 

03 { 

04 require "19-1.php"; // 调 用 配置 文件 

05 Slinkzmysql connect(Shost,Suser.$pass); /连接 主机 

06 mysql_select_db($db_name, $link); // 选 择 数据 库 

07 $sql="select * from $table user where username-'$ COOKIE[username]": 

08 $result-mysql query(Ssql.Slink); /发 送 验证 用 户 身份 的 SQL 请 求 

09 $row=mysql_fetch_array($result); /用户 信息 置 入 数组 

10 if (Stowl'admin']--"1") // 如 果 用 户 是 管理 员 ， 则 执行 以 下 操作 
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11 { 
12 ifl$ POST[action']) // 如 果 没 有 发 送 表单 变量 ， 则 显示 HTML 

13 

14 echo "<center>"; 

15 echo "<h3> 日 志 管理 </h3>"; 

16 echo "<table cellpadding=\"1\" cellspacing=\"1\" align=\"center\" bgcolor=\"#000000\" 
width=\"100%\">"; 

17 echo "<form method=\"post\" action=\"$PATH_INFO\">"; 

18 $sql="select * from $table_log"; 

19 $result=mysql_query($sql,$link); 

20 echo "<tr>"; 

21 echo "<td bgcolor=\"#ccffcc\">id</td><td bgcolor=\"#ccffcc\"> 标 题 </td><td bgcolor= 
\"#ccffcc\"> 内 容 </td><td bgcolor=\"#ccffcc\"> 操 作 类 型 </td>"; 

22 echo "</tr>"; 

23 while($rowsemysql fetch array(Sresult)) 

24 ( 

25 echo "<tr>"; 

26 echo "<input type=hidden name=id[$i] value-".$rows[id']."»"; 

27 echo "<td bgcolor=\"#eeeeff\">". $rows[id']."«/td»"; 

28 echo "<td bgcolor=\"#eeeeff\"><input type-text value=\"".$rowsf'title']."\" name= 
title[$i] size=10></td>"; 

29 echo "<td bgcolor=\"#eeeeff\"><textarea name-content[$i] rows-3 cols=20> 
".$rows['content']."«/textarea» «/td"; 

30 echo "<td bgcolor=\"#eeeeff\"><input type=radio namecaction[$i] value-del 
checked=1> 删 除 <br><input type=radio name=action[$i] value=edit> 修 改 <br></td>"; 

31 echo "</tr>"; 

32 $i++; 

33 } // 循 环 显示 日 志 内 容 及 操作 

34 echo "<tr>"; 

35 echo "<td colspan=\"4\" bgcolor=\"#eeffee\"><center>"; 

36 echo "<input type=submit value=\" 确 认 提交 \">"; 

37 echo "</center></td>"; 

38 echo "</form>"; 

39 echo "</table>"; 

40 echo "</center>"; 

41 echo "</body>"; 

42 echo "<html>"; 

43 } 

44 else // 如 果 表单 变量 已 经 发 送 

45 i 

46 require "19-1.php"; // 调 用 配置 文件 

47 Slink=mysql_connect($host,$user,$pass); /连接 主机 

48 mysql select db($db name.$link); /| 选择 数据 库 

49 for($i=0;$i<count($_POST[Taction']):$i++) 

50 ( 

51 $temp1-$ POST[id'[Si]; // 循 环 获取 表单 变量 

52 S$temp2=$_POSTTtitle][$i]; 

53 S$temp3=$_POST[content][$i]: 

54 if$ POST[action'][Si]--"del") // 如 果 操作 类 型 为 删除 

55 { 

56 $sql="delete from $table log where id='$temp1"; 
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58 else // 如 果 操 作 类 型 为 修改 

59 t 

60 $sql-"update Stable log set title-'Stemp2' content" '$temp3' where id='$temp1"; 
61 f 

62 mysql_query($sql); /执行 删除 或 者 修改 操作 

63 } 

64 echo "<html>"; 

65 echo "<head>"; 

66 echo "<title> 博 客 程序 </title>"; 

67 echo "<meta http-equiv=\"refresh\" content=\"2; url=19-13.php\">"; 

68 echo "</head>"; 

69 echo "<body>"; 

70 echo "处 理 成 功 ， 正 在 返回 "; 

71 echo "</body>"; 

72 echo "</html>"; 

73 } 

74 } 

75 else // 如 果 用 户 不 是 管理 员 ， 则 显示 信息 
76 { 

TAA echo "HEA Ps S OUR: 

78 } 

79 } 

80 else // 如 果 用 户 没有 登录 ， 则 显示 信息 
81 { 

82 echo "你 还 没有 登录 ,点 <a href=19-8.php> 这 里 </a> 进 行 登录 !; 

83 

84 ?> 


说 明 : 本 实例 的 重点 是 将 数据 库 中 的 内 容 进行 格式 化 输出 。 
单 击 左 侧 的 “日 志 管理 ”链接 ， 相 当 于 执行 实例 19-13 中 的 代码 ， 执 行 结果 如 图 19.8 所 示 。 
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图 19.8 日 志 管理 页 面 执行 结果 


这 里 显示 出 了 已 经 存在 的 日 志 ， 可 以 修改 日 志 的 标题 和 内 容 ， 也 可 以 选择 删除 某 一 条 日 志 ， 按 需 
要 进行 相关 操作 即 可 。 如 果 只 对 某 一 项 进行 操作 ， 其 他 项 保持 不 变 ， 则 操作 类 型 要 选择 “修改 ”， 其 


e. 


wie rPMEHE AAA 


他 《如 标题 与 内 容 ) 保持 不 变 即 可 。 
19.57 ”留言 的 管理 


ED 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 19 章 \ 留 言 的 管理 .wmv 

相对 于 日 志 ， 留 言 是 一 个 更 为 开放 的 窗口 ， 里 面 可 能 充斥 着 大 量 有 用 的 或 者 没有 用 的 信息 ， 甚 至 
包括 乱七八糟 的 广告 或 者 带 病 毒 的 网 页 链接 ， 对 这 些 内 容 要 进行 修改 或 者 删除 。 本 小 节 来 创建 留言 管 
理 的 页 面 。 和 其 他 的 管理 功能 一 样 ， 对 留言 的 管理 也 是 只 有 管理 员 才 有 的 权限 ， 所 以 在 用 户 调用 该 页 
时 要 对 用 户 的 身份 进行 判断 。 

【实例 19-14】 以 下 为 留言 管理 页 的 代码 。 


01 <?php 

02 error_reporting(0); 

03 if($_COOKIE['username']) // 如 果 用 户 已 经 登录 

04 { 

05 require "19-1.php"; // 调 用 配置 文件 

06 $link=mysql_connect($host,$user,$pass); 

07 mysql select db($db name,Slink); 

08 $sql-"select * from $table user where username-'$ COOKIE[username]": 

09 $result-mysql query($sql,Slink); 

10 $row-mysq| fetch array(Sresult); /用 户 信息 置 入 数组 

11 if ($row['admin]=="1") /用 户 为 管理 员 

12 ( 

13 if($ POST[action']) // 未 发 送 表单 变量 时 显示 HTML 

14 { 

15 echo "<center>"; 

16 echo "<h3> 留 言 管理 </h3>"; 

17 echo "<table cellpadding=\"1\" cellspacing=\"1\" align=\"center\" bgcolor=\"#000000\" 
width=\"100%\">"; 

18 echo "<form method=\"post\" action=\"$PATH_INFO\">"; 

19 $sql-"select * from $table gbook"; 

20 S$resultzmysql query($sql.Slink); 

21 echo "<tr>"; 

22 echo "<td bgcolor=\"#ccffcc\"> 作 者 </td><td bgcolor=\"#ccffcc\"> 标 题 </td><td bgcolor 
=\"#ccffcc\"> 内 容 </td><td bgcolor=\"#ccffcc\"> 操 作 类 型 </td>"; 

23 echo "</tr>"; 

24 while($rows=mysql_fetch_array($result) 

25 { 

26 echo "<tr>"; 

27 echo "<input type=hidden name=id[$i] valuez" $rows[id']."»": 

28 echo "<td bgcolor=\"#eeeeff\">".$rows['author']."</td><td bgcolor= \#eeeef > 


«input type-text value-" $rows[title]." namec-title[Si] size=6></td><td bgcolor=\"#eeeeff\"><textarea name= 
content[Si] rows-3 cols-20»" $rows[content]."«/textarea» «/td"; 
29 echo "<td bgcolor=\"#eeeeff\"><input type=radio name-action[$i] value-del 
checked» HP «br» «input type=radio name-action[Si] value-edit» £z «br» «/td»"; 
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30 echo "</tr>"; 

31 $i++; 

32 } // 循 环 显示 留言 内 容 
33 echo "<tr>"; 

34 echo "<td colspan=\"4\" bgcolor=\"#eeffee\"><center>"; 

35 echo "<input type=submit value=\" 确 认 提 交 \">"; 

36 echo "</center></td>"; 

3n echo "</form>"; 

38 echo "</table>"; 

39 echo "</center>"; 

40 echo "</body>"; 

41 echo "<html>"; 

42 ) 

43 else Ini EE ARES ERE 
44 ( 

45 require "19-1.php"; 

46 Slinkzmysql connect(Shost,Suser,$pass); 

47 mysql select db($db name,Slink); 

48 for($i-0;Si«count($ POST[id']);Si-) 

49 { 

50 $temp1=$_POSTTŢ'id'][$i]; UE EE 
51 $temp2-$ POSTT title" (Si), 

52 S$temp3-$ POST[content'[Si]; 

53 if(S$ POST['action'][$i]-"del") // 如 果 操 作 类 型 为 删除 
54 { 

55 $sql="delete from $table gbook where id='$temp1"; 
56 ) 

57 else // 如 果 操 作 类 型 为 修改 
58 { 

59 $sql="update $table gbook set title='$temp2',content='$temp3' where id= 
'$temp1"; 

60 } 

61 mysql query($sql); /执行 操作 SQL 语句 
62 ) 

63 echo "<html>"; 

64 echo "<head>"; 

65 echo "<title> 博 客 程序 </title>"; 

66 echo "<meta http-equiv=\"refresh\" content=\"2; url=19-14.php\">"; 
67 echo "</head>"; 

68 echo "<body>"; 

69 echo "处 理 成 功 ， 正 在 返回 "; 

70 echo "</body>"; 

T1 echo "</html>"; 

72 ) 

73 ) 

74 else /如果 用 户 不 是 管理 员 
75 { 

76 echo "普通 用 户 没有 该 权限 上 

77 ) 

78 ) 

79 else // 如 果 用 户 没 有 登录 
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80 { 
81 echo "你 还 没有 登录 ,点 <a href=19-8.php> 这 里 </a> 进 行 登录 人 "; 
82 ) 

83 ?» 


注意 : 留言 管理 是 管理 员 的 权限 。 
于 该 功能 与 日 志 管 理 类 似 ， 所 以 不 再 给 出 执行 结果 图 。 


19.5.8 注册 用 户 的 管理 


Gl 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 19 章 \ 注 册 用 户 的 管理 .wmv 

对 注册 用 户 进行 管理 也 是 管理 工作 中 一 个 很 重要 的 环节 。 通 过 该 页 面 ， 管 理 员 可 以 修改 注册 用 户 
的 信息 (但 是 一 般 情况 下 ， 不 主张 这 么 做 ) ， 甚 至 可 以 从 库 删 除 某 一 个 注册 用 户 。 

【实例 19-15】 以 下 为 注册 用 户 管理 代码 。 


K | I 实例 19-15: 注册 用 户 管理 


01 <?php 


02 error_reporting(0); 

03 if$ COOKIE[username') /如 果 用 户 已 经 登录 

04 f 

05 require "19-1.php"; // 调 用 配置 文件 

06 $link=mysql_connect($host,$user,$pass); /连接 主机 

07 mysql_select_db($db_name, $link); /选择 数据 库 

08 $sql="select * from $table user where username-'$ COOKIE[username]": 

09 $result=mysql_query($sql,$link); // 验 证 用 户 身 份 

10 Srow=mysql_fetch_array($result); 

11 if ($row['admin"]=="1") // 如 果 用 户 为 管理 员 

12 { 

13 if(IS8 POST['action]) // 如 果 没有 发 送 表 单 变 量 ， 则 显示 HTML 
14 { 

15 echo "<center>"; 

16 echo "<h3> 用 户 管理 </h3>"; 

17 echo "<table cellpadding=\"1\" cellspacing=\"1\" alignz center" bgcolor=\"#000000\" 
width=\"100%\">"; 

18 echo "<form method=\"post\" action=\"$PATH_INFO\">"; 

19 S$sql-"select * from $table user where admin!=1"; 

20 S$result-mysql query($sql.Slink); 

21 echo "<tr>"; 

22 echo "<td bgcolor=\"#ccffcc\">id</td><td bgcolor=\"#ccffcc\"> 用 户 名 </td><td bgcolor= 
V#ccffccv> 了 昵称 </td><td bgcolor=\"#ccffcc\"> 用 户 介绍 </td><td bgcolor=\"#ccffcc\"> 操 作 类 型 </td>"; 

23 echo "</tr>"; 

24 while($rows=mysql_fetch_array($result) 

25 F 

26 echo "<tr>"; 

27 echo "<input type=hidden name=id[$i] value-" $rows[id']."»": 

28 echo "<td bgcolor=\"#eeeeff\">".$rowsŢ'id']."</td>"; 
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29 
30 
31 
32 
33 


echo "<td bgcolor=\"#eeeeff\">".$rows['username"]."</td>"; 

echo "<td bgcolor=\"#eeeeff\">"; 

echo "<input type=text name=nickname[$j value=\"".$rows[nickname"]."" size=6>"; 
echo "</td>"; 

echo "<td bgcolor=\"#eeeeff\"><textarea name=description[$i] rows=3 cols- 


202" $rows[description']."«/textarea» «/td»"; 


34 


echo "<td bgcolor=\"#eeeeff\"><input type=radio name-action[$i] value-del 


checked=1> 删 除 <br><input type=radio name=action[$i] value-edit» f£ e «br» «/td»"; 


35 


else 


echo "</tr>"; 

$i++; 
} // 循 环 显示 用 户 信息 
echo "<tr>"; 


echo "<td colspan=\"5\" bgcolor=\"#eeffee\"><center>"; 
echo "<input type=submit value=\" 确 认 提 交 \">"; 

echo "</center></td>"; 

echo "</form>"; 

echo "</table>"; 

echo "</center>"; 

echo "</body>"; 

echo "<html>"; 


// 如 果 表 单 变量 已 经 发 送 


require "19-1.php"; 
Slinkzmysql connect(Shost,Suser,$pass); 
mysql select db($db name,$link); 
for($i-0;Si«count($ POST[action'];Si-*) 
f 
$temp1=$_POSTŢ'id"][$i]; UA 
$temp2-$ POST[nickname/[Si|; 
S$temp3-$ POST[description'][Si]; 
if($ POST[action'][Si]--"del") 
t 


) 


else 


{ 


} 
mysql guery($sgl); /执行 相关 SQL 操作 


$sql="delete from $table user where id='$temp1"; 


S$sql-"update $table user set nickname-'$temp2' description-'$temp3": 


n 

echo "<html>"; 

echo "<head>"; 

echo "<title> 博 客 程序 </title>"; 

echo "<meta http-equiv=\"refresh\" content=\"2; url=19-15.php\">"; 
echo "</head>"; 

echo "<body>"; 

echo "处 理 成 功 ， 正 在 返回 "; 

echo "</body>"; 

echo "</html>"; 
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78 ) 
79 else // 如 果 用 户 不 是 管理 员 
80 { 

81 echo "普通 用 户 没有 该 权限 ! 

82 

83 ) 

84 else /如 果 用 户 没有 登录 
85 { 

86 echo "你 还 没有 登录 ,点 <a href=19-8.php> 这 里 </a> 进 行 登录 !"; 

87 

88 ?> 


注意 : 注册 用 户 管理 是 管理 员 的 权限 。 
单 击 堪 侧 的 “用 户 管理 ”链接 ， 执 行 结果 如 图 19.9 所 示 。 


图 19.9 用 户 管理 执行 结果 


从 图 19.9 可 以 看 出 ， 管 理 的 对 象 是 除了 管理 员 之 外 的 用 户 ， 但 是 由 于 我 们 现在 并 没有 注册 其 他 的 
用 户 ， 因 此 显示 的 结果 就 为 室 。 不 过 一 般 情 况 下 ， 就 算是 管理 员 也 不 能 随意 更 改 用 户 的 昵称 和 用 户 介 
绍 ， 更 不 能 把 用 户 从 列表 中 删除 。 但 是 ， 出 于 研究 目的 ， 这 些 知 识 还 是 应 该 掌握 。 具 体操 作 方 法 与 修 
改 类 别 相 类 似 ， 不 再 袭 述 。 


19.5.9 添加 新 类 别 页 面 


YA 知识 点 讲解 :光盘 \ 视 频 讲 解 \ 第 19 章 \ 添 加 新 类 别 页 面 .wmv 

博客 程序 在 安装 过 程 中 为 用 户 建立 了 一 个 默认 的 日 志 类 别 ， 这 显然 不 能 满足 用 户 的 需要 。 如 一 个 
程序 爱好 者 ， 可 能 会 写 PHP、ASP 或 者 ISP 等 多 种 类 型 的 日 志 : 一 个 游戏 爱好 者 可 能 会 写 网 络 游戏 、 
单机 游戏 、 家 用 机 游戏 等 多 方面 的 日 志 。 所 以 要 给 予 用 户 创建 日 志 的 权限 。 实 现 该 功能 并 不 复杂 ， 在 
类 别 的 表 中 添加 一 项 记录 ， 然 后 在 用 户 签 写 新 的 日 志 时 选择 相应 的 类 别名 称 即 可 。 

【实例 19-16】 以 下 为 添加 新 类 别 页 面 的 代码 。 


E 实例 19-16: 添加 新 类 别 页 面 
源码 路 径 : 光盘 \ 源 文件 \19\19-16.php 
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01 <?php 

02 error reporting(0); 

03 i$ COOKIE[username]) // 如 果 用 户 已 经 登录 
04 1 

05 require "19-1.php"; 

06 Slinkzmysql connect(Shost,Suser.$pass); 

07 mysql select db($db name,$link); 

08 $sql-"select * from $table user where username-'$ COOKIE[username]"'; 
09 $result-mysgl query($sql,Slink); 

10 $row-mysql fetch array(Sresult); 

11 if ($rowl'admin']--"1") // 验 证 用 户 如 果 为 管理 员 
12 ( 

13 if($ POST[sortname") I|: HTML 

14 { 

15 echo "<script language=\"javascript\">\n"; 

16 echo "function juge(theForm)\n"; 

17 echo "tn"; 

18 echo "tif (theForm.sortname.value == \"\")\n"; 

19 echo "Win"; 

20 echo "t\talert(\" 请 输入 类 别名 称 ! \");\n"; 

21 echo "\t\ttheForm.sortname.focus();\n"; 

22 echo "\t\treturn (false);\n"; 

23 echo "tjn"; 

24 echo "tif (theForm.description.value == \"\")\n"; 

25 echo ^t(n"; 

26 echo "tvalert(\" 请 输入 类 别 描述 ! V)"; 

27 echo "MtheForm.description.focus();n"; 

28 echo "\t\treturn (false);n"; 

29 echo "tjn"; 

30 echo "An"; 

31 echo "</script>\n"; 

32 echo "«center»n"; 

33 echo "<table cellpadding- 1" cellspacing=\"1\" alignz center" bgcolor=\"#000000\" 
width=\"100%\">\n"; 

34 echo "<form method=\"post\" action=\"$PATH_INFOV" onsubmit=\retum juge(this)'» n". 
35 echo "<tr bgcolor=\"#cccc99\">\n"; 

36 echo "<td colspan=\"2\" align=\"center\W"> 添 加 新 类 别 </td>\n"; 

37 echo "</tr>\n"; 

38 echo "<tr bgcolor=\"#cccc99\">\n"; 

39 echo "<td> 类 别名 称 </td>\n"; 

40 echo "<td><input type=\"text\" name=\"sortname\"></td>\n"; 

41 echo "</tr>\n"; 

42 echo "<tr bgcolor=\"#cccc99\">\n"; 

43 echo "<td> 类 别 描述 : </td>\n"; 

44 echo "<td><textarea rows-1 10V cols=\"40\" name=\"description\"> «/textarea» </td>\n"; 
45 echo "</tr>\n"; 

46 echo "<tr bgcolor=\"#cccc99\">\n"; 

47 echo "<td colspan=\"2\"><center><input type=\"submit\" value=\" 确认 1g 3 V» 
</center></td>\n"; 

48 echo "«/tr»n"; 

49 echo "«/form»n"; 

50 echo "«/table»n"; 

Si echo "</center>\n"; 


52 echo "</body>\n"; 


53 echo "«html»n"; 

54 ) 

55 else /执行 操作 
56 f 

57 $sortname-$ POST[sortname]; 

58 S$description-$ POST[description']; 

59 require "19-1.php"; 

60 Slinkzmysql connect(Shost,Suser,$pass); 

61 mysql select db($db name.$link); 

62 $sql-"insert into $table sort(sortname,description)values($sortname','$description')": 
63 mysql query($sql,Slink); /插入 新 类 别 
64 echo "<html>\n ; 

65 echo "<head>\n"; 

66 echo "<title> 博 客 程序 </title>\n"; 

67 echo "<meta http-equiv-V'refreshV" content=\"2; url=19-16.php\">"; 
68 echo "</head>\n"; 

69 echo "<body>\n"; 

70 echo "添加 类 别 成 功 ， 正 在 返回 "; 

71 echo "</body>"; 

72 echo "</html>"; 

73 } 

74 ) 

75 else 

76 ( 

Ya echo "普通 用 户 没有 该 权限 人"; 

78 

79 } 

80 else 

81 { 

82 echo "你 还 没有 登录 ,点 <a href=19-8.php> 这 里 </a> 进 行 登录 !"; 
83 

84 ?> 


当 有 管理 员 登 录 系 统 后 ,就 可 以 调用 该 页 面 来 创建 新 的 日 志 类 别 了 .在 PHP 运行 环境 中 执行 该 PHP 
文件 ， 执 行 结果 如 图 19.10 Bros 

f E [E5177] 
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1910 ”添加 新 类 别 执行 结果 
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这 里 只 需要 输入 新 的 类 别名 称 及 类 别 描述 ， 然 后 单 击 “确认 提交 ”按钮 即 可 。 


注意 : 执行 完 操作 之 后 跳 回 到 重新 输入 新 类 别 的 页 面 ， 不 再 重复 。 当 时 并 不 会 出 现 结果 。 不 过 ， 在 执 
行 操作 “分 类 管理 ”时 或 者 返回 到 首页 就 能 看 到 结果 。 


19.5.10 ”留言 显示 与 发 表 页 面 


KB 知识 点 讲解 :光盘 \ 视 频 讲 解 \ 第 19 章 \ 留 言 显 示 与 发 表 页 面 .wmv 

一 个 简单 的 留言 短 ， 可 以 有 效 地 在 管理 者 与 普通 浏览 者 之 间 连 起 一 条 纽带 ， 所 以 通常 的 博客 程序 
都 会 附带 一 个 留言 短 。 这 里 介绍 的 博客 的 程序 也 有 一 个 简单 的 留言 短 。 由 于 只 是 一 个 附带 的 产品 ， 所 
以 其 功能 都 尽 可 能 简单 ， 把 显示 与 用 户 添加 的 功能 统统 集成 到 一 个 文件 之 中 。 

【实例 19-17】 以 下 为 留言 显示 与 发 表 页 面 代码 。 
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实例 19-17: 留言 显示 与 发 表 页 面 


源码 路 径 ， 光 盘 \ 源 文件 \19\19-17.php 


01 <?php 

02 error_reporting(0); 

03 require "19-3.php"; // 调 用 头 文件 
04 il$_POST[title]) // 如 果 没 有 发 送 表单 变量 ， 则 显示 HTML 
05 { 

06 echo "<table width=\"80%\">\n"; 

07 echo "<tr>"; 

08 echo "<td width=\"20%\">"; 

09 require "19-4.php"; 

10 echo "</td>"; 

11 echo "<td width=\"80%\">"; 

12 echo "<table cellpadding = \"1\"cellspacing=\"1\"width = \"100%\"align = \"center\"bgcolor = \"#000000 
">n"; 

13 require "19-1.php"; 

14 $link=mysql_connect($host,$user,$pass); 

15 mysql_select_db($db_name, $link); 

16 $sql="select id from $table gbook"; 

I $resultzmysql query($sql,Slink); 

18 $msg count-mysq| num rows(Sresult); /总 条 数 
19 $p count-ceil($msg count/10); /总 页 数 
20 echo "<tr>"; 

21 echo "<td bgcolor=\#eeeeff"> 全 部 留言 </td>"; 

22 echo "</tr>"; 

23 echo "<tr>"; 

24 echo "<td bgcolor=\"#eeeeff\">"; 

25 if ($_GET['page']==0 && !$_GET['page']) 

26 $page=1; 

27 else 

28 $page-$ GET[pageT; 

29 $s=($page-1)*10+1; 

30 $s=$s-1; 

exi $sgl-"select * from $table gbook order by id desc limit $s, 10"; 
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32 $result-mysgl query($sql.Slink); 

33 $nums-mysq| num rows(S$result); 

34 if($nums«1) echo "还 没有 任何 留言 记录 ! "; 

35 else 

36 { 

37 while($rows-mysql fetch array($result)) 

38 { 

39 echo $rowsf'title']."</a>"; 

40 echo "<p>"; 

41 echo $rows[author']." T" $rows[date." BE: "; 
42 echo "<p>"; 

43 echo $rows['content"; 

44 echo "<hr width=100%>"; 

45 ) 

46 ) 

47 echo "</td>"; 

48 echo "</tr>"; 

49 echo "<tr>"; 

50 echo "<td bgcolor=\"#eeeeff\">"; 

51 $prev_page=$page-1; 

52 $next_page=$page+1; 

53 if ($page<=1){ 

54 echo "第 一 页 |"; 

55 ) 

56 else( 

57 echo "<a href-'$PATH INFO?page-1'» $8 —71«/a» | "; 
58 ) 

59 if ($prev page«1)( 

60 echo "上 一 页 |" 

61 ) 

62 else( 

63 echo "<a href-'$PATH INFO?page-$prev page'».E—71«/a» |", 
64 } 

65 if ($next page»$p count)[ 

66 echo "下 一 页 | "; 

67 ) 

68 else( 

69 echo "<a href-'$PATH INFO?page-$next page'» T —71«/a* | "; 
70 ) 

71 if($page»-$p count) 

72 echo "最 后 一 页 </p>\ 

73 ) 

74 elsef 

75 echo "<a href='$PATH_INFO?page=$p_count> 最 后 一 页 </a></p>\n"; 
76 } 

ud echo "</td>"; 

78 echo "</tr>"; 

T9 echo "</table>"; 

80 echo "<p>"; 

81 echo "<table cellpadding = \"1\" cellspacing = \"1\" width = 110096" align = \"center\" bgcolor = 
\"#000000\">\n"; 
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82 echo "<form action=19-17.php method=post>"; 

83 echo "<tr bgcolor=\"#eeffee\"><td>"; 

84 echo "发 表 新 留言 :"; 

85 echo "</td></tr>"; 

86 echo "<tr bgcolor=\"#eeffee\"><td>"; 

87 echo "留言 题目 : «input type-text name=title>"; 

88 echo "</td></tr>"; 

89 echo "<tr bgcolor=\"#eeffee\"><td>"; 

90 echo "留言 内 容 : <br><textarea name=content rows=5 cols=40></textarea>"; 
91 echo "</td></tr>"; 

92 echo "<tr bgcolor=\"#eeffee\"><td>"; 

93 echo "<input type=submit value=\" 发 表 \">"; 

94 echo "</td></tr>"; 

95 echo "</form>"; 

96 echo "</table>"; 

97 echo "</td>"; 

98 echo "</tr>"; 

99 echo "</table>"; 

100 echo "</td>"; 

101 echo "</tr>"; 

102 echo "</table>"; 

103 ) 

104 else // 如 果 已 经 发 送 表单 变量 ， 则 执行 操作 
105 { 

106 $title=$_POST[title]; 

107 S$content-$ POST[content]; 

108 $date-$date-date("Y 4# n A d R"); 

109 if(!$_COOKIE['username"]) 

110 { 

111 $username" EZ"; 

112 ) 

113 else 

114 { 

115 $username=$_COOKIE['username"]; 

116 ) 

117 require "19-1.php"; 

118 Slinkzmysql connect(Shost $user.$pass); 

119 mysql select db($db name,Slink); 

120 $sql="insert into $table gbook(author,title,content,date)values($username!', 'Stitle', '$content', 'Sdate")"; 
121 mysql query(S$sql,Slink); // 插 入 留言 内 容 到 表 中 
122 echo "<meta http-equiv=\"refresh\" content=\"2; url=19-17.php\">"; 
123 echo "</head>\n"; 

124 echo "<body>\n"; 

125 echo "添加 留言 成 功 ， 正 在 返回 "; 

126 echo "</body>"; 

127 echo "</html>"; 

128 ) 

129 7> 


说 明 : 该 功能 方便 普通 用 户 甚至 是 匿名 用 户 发 表 、 浏 览 留言 。 
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图 19.11 查看 留言 页 面 执行 结果 


此 时 没有 任何 留言 ， 可 以 使 用 下 方 给 出 的 表单 添加 新 的 留言 。 输 入 留言 标题 与 留言 内 容 之 后 ， 单 
击 “ 发 表 ” 按 钮 即 可 ， 执 行 结果 如 图 19.12 所 示 。 
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图 19.12 发 表 留 言 执行 结果 
从 图 19.12 可 以 看 出 ， 正 确 显示 出 了 用 户 所 提交 的 留言 内 容 ， 说 明 程 序 正 常 运 行 。 


19.5.11 新 用 户 注册 页 面 


雪 知识 点 讲解 : 光盘 \ 视 频 讲 解 \ 第 19 章 \ 新 用 户 注册 页 面 .wmv 

一 个 博客 程序 的 用 户 当然 不 能 只 有 管理 员 ， 也 应 该 有 更 多 的 普通 使 用 者 。 本 小 节 来 创建 新 用 户 注 
册页 面 。 在 进行 注册 时 要 先 判断 用 户 名 是 否 存在 ， 如 果 存在 ， 则 给 出 相应 的 提示 。 反 之 ， 则 将 用 户 输 
入 信息 添加 到 表 中 。 

【实例 19-18】 以 下 为 新 用 户 注册 页 面 。 
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PHP 网 络 编程 技术 详解 


实例 19-18: 新 用 户 注册 
源码 路 径 : 光盘 \ 源 文件 \19\19-18.php 


01 <?php 

02 if($ POSTFadmin')) /如 果 没 有 软 认 参数 ， 则 显示 HTML 
03 { 

04 echo "<html>"; 

05 echo "<head>"; 

06 echo "<title> 注 册 新 用 户 </title>"; 

07 echo "</head>"; 

08 echo "<body>"; 

09 echo "<script language-'' javascript"; 
10 echo "function juge(theForm)"; 

11 echo "(": 

12 echo "if (theForm.admin.value == \"\")"; 

13 echo "{"; 

14 echo "alert(\" 请 输入 用 户 名 称 ! \");"; 

15 echo "theForm.admin.focus();"; 

16 echo "return (false);": 

ihn echo "^: 

18 echo "if (theForm.pass.value == \"\")"; 

19 echo "(*: 

20 echo "alert(\" 请 输入 用 户 密码 ! Vy": 

21 echo "theForm.pass.focus();"; 

22 echo "return (false);"; 

23 echo "^: 

24 echo "if (theForm.pass.value.length « 8 )"; 
25 echo "(*: 

26 echo "alert(\" 密 码 至 少 要 8 位 ! Vy" 

2 echo "theForm.pass.focus();"; 

28 echo "return (false);"; 

29 echo "^: 

30 echo "if (theForm.re pass.value !-theForm.pass.value)"; 
31 echo "(*; 

32 echo "alert(\" 确 认 密码 与 密码 不 一 致 ! V 
33 echo "theForm.re pass.focus();"; 

34 echo "return (false);": 

35 echo "j^; 

36 echo "if (theForm.nickname.value == \\V) 
37 echo "(*: 

38 echo "alert(\" 请 输入 昵称 ! V": 

39 echo "theForm.nickname.focus();"; 

40 echo "return (false);"; 

41 echo "}"; 

42 echo "}"; 

43 echo "</script>"; 

44 echo "<center>"; 

45 echo "<table width = \"80%\" cellpadding = \"1\" cellspacing = V'1V align = V'center" bgcolor = 
\"#000000\">"; 

46 echo "<form method=\"post\" action=\"$PATH_INFO\" onsubmit=\"return juge(this)\">"; 
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else 


第 19 章 PHP 博客 程序 


echo "<tr bgcolor=\"#cccc99\">"; 

echo "<td colspan=\"2\" align=\"center\"><font size=\"5px\"> 注 册 新 用 户 </font></td>"; 
echo "</tr>"; 

echo "<tr bgcolor=\"#cccc99\">"; 

echo "<td> 用 户 名 : 〈 后 台 登 录 ) </td>"; 

echo "<td><input type=\"text\" name=\"admin\"></td>"; 

echo "</tr>"; 

echo "<tr bgcolor=\"#cccc99\">"; 

echo "<td> 用 户 密码 : 〈 不 小 于 8 位 ) </td>"; 

echo "<td><input type=\"password\" name=\"pass\" size=\"21\"></td>"; 
echo "</tr>"; 

echo "<tr bgcolor=\"#cccc99\">"; 

echo "<td> 确 认 窗 码 : </td>"; 

echo "<td><input type=\"password\" name=\"re_pass\" size=\"21\"></td>"; 
echo "</tr>"; 

echo "<tr bgcolor=\"#cccc99\">"; 

echo "<td> FH P E-mail: (AE) </td>"; 

echo "<td><input type=\"text\" name=\"email\"></td>"; 

echo "</tr>"; 

echo "<tr bgcolor=\"#cccc99\">"; 

echo "<td> 用 户 昵称 : (MERT) </td>"; 

echo "<td><input type=\"text\" name=\"nickname\"></td>"; 

echo "</tr>"; 

echo "<tr bgcolor=\"#cccc99\">"; 

echo "<td> 用 户 介绍 : </td>"; 

echo "<td><textarea rows=\"5\" cols=\"30\" name=\"description\"></textarea></td>"; 
echo "</tr>"; 

echo "<tr bgcolor=\"#cccc99\">"; 

echo "<td colspan=\"2\"><center><input type=\"submit\" value=\" 下 一 步 \"></center></td>"; 
echo "</tr>"; 

echo "</form>"; 

echo "</table>"; 

echo "</center>"; 

echo "</body>"; 

echo "<html>"; 


// 如 果 有 POST 参数 ， 则 执行 操作 


$username-$ POST[admin7; // 获 得 参数 
$password=md5($_POST[pass]); 

$nickname=$_POST[nickname']; 

$email-$ POST['email'; 

S$description-$ POST[description']; 

require "19-1.php"; 

Slink=mysql_connect($host, $user,$pass) or die(mysql error()); 

mysql select db($db name,$link); /| 选择 数据 库 
$sql="select username from Stable user where username-'$username""; 
$resultzmysql query($sql.Slink); 


$nums-mysq| num rows(Sresult); // 获 取 重 名 用 户 
if($nums!=0) echo "用 户 名 已 经 存在 ! 点 <a href='# onclick=history.go(-1)> 这 里 </a> 返 回 "; 
else // 如 果 不 存 在 重 名 用 户 
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SERERE 


98 n 

99 $sql-"insert into Stable user(username,password,nickname,email,description)values 
('Susername','$password'/'$nickname','$email' '$description")"; 

100 mysql query($sql,Slink) or die(mysql error()); /发 送 添加 用 户 信息 的 SQL 请 求 
101 echo "<html>"; 

102 echo "<head>"; 

103 echo "<title> 注 册 新 用 户 </title>"; 

104 echo "</head>"; 

105 echo "<body>"; 

106 echo "</center>"; 

107 echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\" align=\"center\" bgcolor= 
\"#000000\">"; 

108 echo "<tr bgcolor=\"#cccc99\">"; 

109 echo "<td align=\"center\"><font size=\"5px\"> 注 册 用 户 </font></td>"; 

110 echo "</tr>"; 

111 echo "<tr bgcolor=\"#cccc99\">"; 

112 echo "<td align=\"center\"><font size=\"3px\"> 成 功 注册 ! </font></td>"; 

113 echo "</tr>"; 

114 echo "<tr bgcolor=\"#cccc99\">"; 

115 echo "<td align=\"center\"> 23«a href=\"19-8.php\"> 这 里 </a> 登 录 </td>"; 

116 echo "</tr>"; 

117 echo "</table>"; 

118 echo "</center>"; 

119 echo "</body>"; 

120 echo "</html>"; 

121 3 

122 ) 

123 ?» 


在 PHP 运行 环境 中 执行 该 PHP 文件 ， 执 行 结果 如 图 19.13 所 示 。 
按 要 求 输入 想 要 注册 的 用 户 名 ， 再 输入 相应 的 密码 、 信 箱 、 简 介 等 内 容 即 可 。 单 击 “ 下 一 步 ” 按 
钮 ， 将 出 现 如 图 19.14 所 示 的 执行 结果 。 
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图 19.13 注册 新 用 户 执行 结果 19.4 成功 注册 新 用 户 执行 结果 


出 现 如 图 19.14 所 示 画 面 ， 说 明 新 用 户 注册 成 功 。 


19.5.12 ”用户 退 出 登录 页 面 


YA 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 19 章 \ 用 户 退 出 登录 页 面 .wmv 

因为 这 里 采用 的 Cookie 机 制 是 最 短 生 命 期 ， 即 浏览 器 关闭 ， 登 录用 户 注册 的 Cookie 即 失效 。 但 
是 为 了 方便 用 户 操作 还 是 有 必要 创建 这 样 一 个 页 面 。 实 现 功能 相当 简单 一 一 清除 用 户 注册 Cookie 并 返 
可 首页 。 

【实例 19-19】 具 体内 容 请 参看 以 下 代码 。 


E^ | 实例 19-19: 用 户 退 出 登录 具体 内 容 00 
源码 路 径 ， 光 盘 \ 源 文件 \19\19-19.php 


01 <?php 

02 setcookie("username",""); // 把 相关 变量 置 为 空 值 

03 echo "<html>"; 

04 echo "<head>"; 

05 echo "<title> 退 出 登录 </title>"; 

06 echo "<meta http-equiv=\"refresh\" content=\"2; url=19-3.php\">"; 

07 echo "</head>"; 

08 echo "<body>"; 

09 echo "已 经 退出 ， 两 秒 后 返回 ! " 

10 echo "</body>"; 

iL Tes 

当 登 录用 户 单 击 页 面 左 侧 中 间 的 “退出 ”链接 时 ， 相 当 于 执行 实例 19-19， 程 序 将 会 清空 用 户 登 录 
的 Cookie 完成 退出 任务 。 


至 此 ， 整 个 博客 系统 的 所 有 页 面 均 创 建 完毕 。 
196 ”进一步 完善 


YA 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 19 章 \ 进 一 步 完 善 .wmv 
虽然 这 个 简单 的 博客 程序 已 经 能 够 正常 运行 了 ， 但 还 存在 很 多 不 足 ， 与 网 上 同类 程序 相 比 功能 上 
还 差 得 比较 远 。 在 这 里 总 结 本 程序 的 不 足 ， 并 给 出 相关 的 解决 思路 ， 有 兴趣 的 读者 可 以 自行 解决 。 比 
较 来 说 ， 有 以 下 儿 个 方面 : 
加 ”没有 对 用 户 输入 内 容 进行 检测 。 用 户 的 输入 内 容 五 花 八 门 ， 更 有 用 户 会 输入 恶意 代码 。 解 决 
这 个 问题 可 以 通过 相应 的 字符 串 操 作 函 数 ， 对 用 户 输入 信息 进行 处 理 。 
回 ”没有 文件 上 传 功能 。 有 时 用 户 需 要 通过 博客 程序 把 本 地 的 文件 如 图 片上 传 到 服务 器 。 解 决 这 
个 问题 可 以 为 管理 员 专门 再 建 一 个 文件 上 传 的 页 面 。 关 于 如 何 上 传 文件 请 参见 第 8 章 。 
回 ”没有 友情 链接 。 通 常 的 博客 程序 都 有 一 个 友情 链接 ， 以 使 管理 者 可 以 对 同类 的 或 者 其 他 朋友 
的 网 站 建立 链接 ， 便 于 交流 。 这 个 实现 起 来 也 不 复杂 ， 只 需要 建 一 个 专门 的 表 用 于 放置 友情 
链接 信息 ， 然 后 在 显示 时 显示 相应 的 网 站 链接 即 可 。 
经 过 以 上 功能 的 增加 ， 该 博客 程序 的 功能 相对 来 说 就 比较 完善 了 。 
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197 关于 RSS 内 容 聚 合 


YA 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 19 章 \ 关 于 RSS 内 容 聚 合 .wmv 

现在 所 见 到 博客 站 点 中 通常 都 有 一 个 RSS 的 链接 ， 这 也 是 博客 程序 一 个 明显 的 特征 。 网 络 上 曾经 
流行 这 样 一 段 话 “blogging without RSS is like swimming without water”， 没 有 了 RSS 的 写 博客 就 相当 
没有 水 的 游泳 。 看 起 来 RSS 对 博客 起 着 相当 重要 的 作用 。 虽 然 这 已 经 不 属于 PHP 编程 的 范畴 ， 作 为 相 
关 知 识 ， 读 者 有 必要 作 一 下 了 解 。 

那么 究竟 什么 是 RSS， 它 与 博客 程序 又 有 什么 联系 呢 ? 

RSS (Really Simple Syndication) 是 一 种 描述 和 同步 网 站 内 容 的 格式 ， 是 目前 使 用 最 广泛 的 XML 
应 用 。RSS 搭建 了 一 个 信息 迅速 传播 的 技术 平台 , 使 得 每 个 人 都 成 为 潜在 的 信息 提供 者 。 发 布 一 个 RSS 
文件 后 ， 这 个 RSS Feed 中 包含 的 信息 就 能 直接 被 其 他 站 点 调用 ， 而 且 由 于 这 些 数据 都 是 标准 的 XML 
格式 ， 所 以 也 能 在 其 他 的 终端 和 服务 器 中 使 用 。 

如 果 从 RSS 阅读 者 的 角度 来 看 ， 完 全 不 必 考 虑 它 到 底 是 什么 意思 ， 只 要 简单 地 理解 为 一 种 方便 的 
信息 获取 工具 就 可 以 了 。RSS 获取 信息 的 模式 与 加 入 邮件 列表 〈 如 电子 杂志 和 新 闻 邮 件 ) 获取 信息 有 
一 定 的 相似 之 处 ， 也 就 是 可 以 不 必 登 录 各 个 提供 信息 的 网 站 而 通过 客户 端 浏览 方式 〈 称 为 “RSS 阅读 
器 ”) 或 者 在 线 RSS 阅读 方式 获取 这 些 内 容 。 例 如 ， 通 过 一 个 RSS 阅读 器 ， 可 以 浏览 新 浪 新 闻 ， 同 时 
也 可 以 浏览 搜狐 或 者 百度 新 闻 (如 果 用 户 采 用 了 RSS 订阅 的 话 ) 。 

在 许多 新 闻 信 息 服务 类 网 站 中 ， 会 看 到 这 样 的 按钮 EE 到 EC 到， 有 的 网 站 使 用 一 个 图 标 ， 有 的 
同时 使 用 两 个 ， 这 就 是 典型 的 提供 RSS 订阅 的 标志 ， 这 个 图 标 一 般 链 接 到 订阅 RSS 信息 源 的 URL。 
当然 ， 即 使 不 用 这 样 的 图 标 也 是 可 以 的 ， 只 要 提供 订阅 RSS 信息 源 的 URL 即 可 。 

概括 来 说 ，RSS 其 实 就 是 一 种 站 点 与 站 点 之 间 的 信息 共享 方式 〈 也 称 内 容 聚 合 ) 。 使 用 该 方式 之 
后 ， 所 有 使 用 者 都 变 成 了 潜在 的 信息 提供 者 ， 这 样 会 更 有 利于 普通 网 络 使 用 者 发 现 网 站 内 容 的 更 新 。 

关于 RSS 的 知识 就 简要 介绍 到 这 里 ， 有 兴趣 的 读者 可 以 查阅 相关 的 专门 书籍 以 了 解 更 多 内 容 。 


19.8 本 X 小 结 


本 章 为 读者 介绍 了 什么 是 Blog， 普 及 了 Blog 的 知识 ， 而 重点 是 介绍 如 何 用 PHP 程序 来 完成 一 个 
简单 的 Blog 程序 。 把 一 个 简单 的 博客 程序 分 解 为 了 19 个 组 成 部 分 逐个 来 讲解 ， 并 对 执行 结果 进行 了 
调试 分 析 。 通 过 本 章 学 习 ， 读 者 对 什么 是 博客 、 如 何 实现 一 个 博客 都 有 了 一 个 更 深层 次 的 认识 ， 同 时 
对 于 用 PHP 进行 MySQL 数据 库 的 操作 更 有 了 新 的 提高 。 
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第 20 章 ”简单 的 BBS 系统 


BBS 是 英文 Bulletin Board System 的 缩写 , 翻译 成 中 文 为 “电子 布告 栏 系统 "或 “电子 公告 牌 系统 ”。 
BBS 是 一 种 电子 信息 服务 系统 ， 它 向 用 户 提供 了 一 块 公共 电子 白板 ， 每 个 用 户 都 可 以 在 上 面 发 布 信息 
或 提出 看 法 ， 早 期 的 BBS 由 教育 机 构 或 研究 机 构 管理 ， 现 在 多 数 网 站 上 都 建立 了 自己 的 BBS A. 
供 网 民 通 过 网 络 来 结交 更 多 的 朋友 ， 表 达 更 多 的 想法 。 目 前 国内 的 BBS 已 经 十 分 普遍 ， 可 以 说 是 不 计 
其 数 ， 其 中 BBS 大 致 可 以 分 为 5 类 : 

校园 BBS: CERNET 建立 以 来 ， 校 园 BBS 很 快 地 发 展 起 来 ， 目 前 很 多 大 学 都 有 了 BBS, JL 

乎 遍及 全 国 。 像 清华 大 学 、 北 京 大 学 等 都 建立 了 自己 的 BBS 系统 ， 清 华 大 学 的 “水 木 清华 ” 
很 受 学 生 和 网 民 们 的 喜爱 。 大 多 数 BBS 是 由 各 校 的 网 络 中 心 建 立 的 ， 也 有 私人 性 质 的 BBS 。 


商业 BBS: 这 里 主要 是 进行 有 关 商 业 的 商业 宣传 、 产 品 推荐 等 ， 目 前 手机 的 商业 站 、 计 算 机 
的 商业 站 、 房 地 产 的 商业 站 比比 皆 是 。 

专业 BBS: 这 里 所 说 的 专业 BBS 是 指 部 委 和 公司 的 BBS, 它 主要 用 于 建立 地 域 性 的 文件 传输 
和 信息 发 布 系统 。 

情感 BBS: 主要 用 于 交流 情感 ， 是 许多 娱乐 网 站 的 首选 。 

个 人 BBS: 有 些 个 人 主页 的 制作 者 在 自己 的 个 人 主页 上 建设 了 BBS， 用 于 接受 别人 的 想法 ， 


更 有 利于 与 好 友 进行 沟通 。 
本 章 就 通过 PHP 来 设计 一 个 简单 的 BBS 系统 ， 包 括 BBS 相关 数据 表 的 设计 、 用 户 的 注册 与 登录 
设计 、 用 户 发 帖 设 计 、 主 题 的 显示 与 回复 设计 、 管 理 员 对 帖子 的 管理 、 用 户 的 管理 等 内 容 。 通 过 本 章 
的 学 习 ， 读 者 会 更 进一步 掌握 用 PHP 解决 实际 问题 的 能 力 。 


20.1 设计 数据 库 表 


数据 库 表 的 设计 是 Web 应 用 程序 开发 中 一 个 很 重要 的 环节 ， 表 结构 设计 的 好 坏 直接 影响 着 应 用 程 
序 的 执行 效率 。 一 个 设计 清晰 、 结 构 合理 的 表 是 高 效应 用 程序 的 基础 。 本 节 就 来 分 析 一 下 简单 BBS 系 
统 的 表 结构 应 该 如 何 设计 。 


20.1.1 用 户 数据 表 的 设计 
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本 小 节 先 来 学 习 一 下 简单 的 BBS 用 户 数据 表 的 设计 。 

一 般 的 用 户 表 应 该 包括 如 下 内 容 : 索引 ID、 用 户 名 (用 户 登录 时 使 用 的 名 称 ) 、 密 码 〈 用 户 登 录 
时 使 用 的 密码 ) 、 昵 称 〈 与 用 户 名 不 同 ， 用 户 名 在 用 户 登 录 时 显示 ， 其 他 时 候 不 显示 ， 用 户 名 具有 唯 
一 性 ; 而 昵称 则 在 用 户 发 帖 时 在 论坛 上 显示 , 所 有 用 户 昵称 允许 出 现 重复 )、 性 别 (记录 用 户 的 性 别 》、 
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电子 信箱 〈 判 断 用 户 身 份 的 一 个 重要 标志 ) 、 论 坛 图 像 〈 用 户 发 帖 时 显示 的 图 像 ) 、 论 坛 签名 〈 跟 在 
发 的 帖子 后 面 的 签名 ) 、 发 帖 数 〈 记 录用 户 总 共 的 发 帖 数 量 ) 、 注 册 时 间 《〈 记 录用 户 注册 的 时 间 ) 、 
版 主 〈 记 录用 户 的 权限 ， 分 为 普通 用 户 、 版 主 、 超 级 版 主 等 儿 种 ) 、 等 级 〈 由 发 帖 数 所 规定 的 一 个 等 
级 ， 发 帖 数 越 多 ， 等 级 越 高 )》 、 其 他 《备用 ， 以 放置 用 户 其 他 信息 ) 。 每 个 字段 及 类 型 如 表 20.1 所 示 。 


表 20.1 用 户 数据 表 members 字段 类 型 及 含义 


字 段 名 类 型 ft HH 其 他 属性 
id im 5 记录 每 个 用 户 的 编号 ， 具 有 唯一 性 icon 
primary key 

name varchar 记录 每 个 用 户 的 用 户 名 

password varchar 记录 用 户 的 密码 ， 用 MD5 加 密 保存 

nickname varchar 用 户 昵称 

Sex enum(boy girl) 记录 用 户 性 别 default 'boy" 
Email varchar 80 记录 用 户 电 子 信箱 

photo varchar | so | gxHnme | 

q name varchar 

pstmm | im 

reg date varchar 

admin in | i | 记录 用 户 的 类 型 《管理 员 或 者 普通 用 户 ) | 

levie int 

other varchar 


注意 : 注意 数据 表 中 其 他 属性 的 设置 。 


20.1.2 ”论坛 分 类 数据 表 的 设计 
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一 个 论坛 通常 都 包括 很 多 子 栏目 ， 如 一 个 以 编程 为 主题 的 论坛 下 面 可 能 分 为 技术 区 与 娱乐 区 ， 技 
术 区 可 能 又 会 分 为 网 络 编程 、 应 用 程序 编程 等 ， 下 面 可 能 还 会 有 更 复杂 的 划分 。 娱 乐 区 也 可 能 分 为 灌 
水 区 、 贴 图 区 等 。 所 有 这 些 分 类 信息 都 要 保存 在 一 个 专门 的 表 中 。 

按照 以 上 考虑 ， 论 坛 分 类 数据 表 应 包括 以 下 内 容 : 索引 ID、 主 分 类 ID. (论坛 的 大 类 ， 如 果 某 一 分 
类 项 为 主 分 类 ， 则 该 项 值 为 0， 反 之 该 项 值 为 其 主 分 类 ID 的 ID 号 ) 、 论 坛 分 类 名 称 〔 记 录 某 一 个 分 
类 的 名 称 ) 、 论 坛 分 类 介绍 (向 用 户 介绍 该 分 类 的 主要 内 容 ) 、 最 后 帖子 的 ID 号 (记录 最 后 一 条 帖子 
内 容 以 显示 给 用 户 ) 、 该 分 类 的 总 帖子 数 〔 记 录 所 属 该 分 类 的 所 有 帖子 的 数量 ) 、 该 分 类 的 总 主题 数 
(帖子 数 包括 主题 数 ) 、 其 他 (备用 ， 以 存放 该 分 类 的 其 他 信息 ) 。 每 个 字段 及 其 类 型 如 表 20.2 
所 示 。 


表 20.2 论坛 分 类 数据 表 topic 的 字段 类 型 及 含义 


作 用 
记录 每 个 类 别 的 编号 ， 具有 唯一 性 


其 他 属性 


auto_increment 


primary ke; 
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EI 
T RS ft 用 其 他 属性 
. 记录 该 类 别 所 属 主 类 别 ， 如 果 该 类 别 即 为 主 类 别 ， 
VM Witt 0 
topic name 记录 该 类 别 的 名 称 


记录 该 类 别 的 简介 
记录 该 类 别 最 后 帖 号 
记录 该 类 别 总 帖 数 
记录 该 类 别 主题 数 
其 他 


topic description 


last post id 


.post count 


.post m count 


other 


注意 : 注意 数据 表 中 其 他 属性 的 设置 。 
至 此 ， 论 坛 分 类 表 的 设计 也 告 一 段落 。 
20.1.3 ”帖子 数据 表 的 设计 
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简单 的 论坛 系统 的 帖子 数据 表 采 用 这 样 的 结构 : 索引 ID、 所 属 分 类 ID. (记录 该 帖子 属于 哪 一 个 论 
坛 分 类 ， 该 值 等 于 论坛 分 类 表 中 的 ID 号 ) 、 回 复 ID 〈 该 帖子 是 对 哪 一 条 帖子 的 回复 ， 如 果 帖 子 本 身 
就 是 主题 ， 则 该 值 为 0) 、 帖 子 作 者 的 ID 号 〈 这 一 条 记录 帖子 作者 的 索引 号 ， 以 便 通 过 该 ID 号 显示 
作者 的 相关 信息 ) 、 帖 子 作者 的 名 称 、 帖 子 作者 的 IP 地 址 (记录 作者 的 IP 地 址 ) 、 帖 子 类 型 (可 分 
为 求助 帖 、 原 创 帖 、 转 帖 等 多 个 类 型 ) 、 帖 子 的 标题 、 帖 子 的 内 容 〈 这 一 条 最 为 关键 ， 记 录 所 发 帖子 
的 内 容 ) 、 帖 子 浏览 量 、 帖 子 回复 量 、 帖 子 发 送 时 间 〈 记 录 帖 子 发 送 于 何 时 ) 、 回 复 时 间 (记录 该 帖 
子 最 后 回复 的 时 间 ) 、 其 他 〈 备 用 ， 记 录 帖 子 的 其 他 信息 ) 。 每 个 字段 及 其 类 型 如 表 20.3 所 示 。 
表 20.3 ”帖子 记录 表 posts 的 字段 类 型 及 含义 


字段 名 类 型 “| «em 作用 其 他 属性 
id int 5 。 | 记录 每 个 帖子 的 编号 ， 具 有 唯一 性 人 
rimary key 
topic id int 5 记录 该 帖子 所 属 的 论坛 类 别 
re id int 5 记录 该 帖子 所 属 的 主题 。 如 果 该 帖子 即 为 主题 ， 则 该 值 为 0 
. poster id int 5 记录 发 帖 者 的 编号 
. poster ip varchar 23 记录 发 帖 者 的 IP 地 址 
. poster varchar 12 记录 发 帖 者 的 名 字 
. poster type varchar 10 记录 帖子 类 型 
title varchar 40 记录 帖子 标题 
content text 记录 帖子 内 容 
View_count int 5 记录 帖子 浏览 量 
re count int 5 记录 帖子 回复 量 


st time varchar 40 记录 发 帖 时 间 
_post re time | varchar 40 记录 最 后 回复 时 间 
other varchar 200 | 其 他 
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注意 : 注意 数据 表 中 其 他 属性 的 设置 。 


帖子 数据 表 的 设计 也 宣告 完成 。 至此， 论坛 所 用 到 的 3 个 表 都 已 经 建立 完成 。 从 20.2 节 开 始 就 通 
过 代码 来 逐步 实现 论坛 的 所 有 功能 。 


202 准备 工作 


从 本 节 开 始 将 通过 具体 代码 来 一 步 步 实现 论坛 的 所 有 功能 。 不 过 在 具体 实施 之 前 ， 有 一 些 准备 工 
作 必 须要 先 完成 。 本 节 就 来 解决 这 个 问题 。 


20.2.1 配置 文件 的 创建 
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通常 情况 下 ， 程 序 所 访问 的 主机 名 、 连 接 主 机 的 用 户 名 、 用 户 密码 及 数据 库 名 都 是 固定 不 变 的 。 
而 要 创建 的 各 种 表 名 ， 在 创建 后 也 是 不 变 的 。 所 以 把 这 些 重要 的 变量 单独 做 成 配置 文件 是 很 有 必要 的 。 
即 该 配置 文件 中 存放 着 程序 所 需要 的 数据 库 的 主机 名 、 连 接 主机 的 用 户 名 、 用 户 密码 、 数 据 库 名 、 表 
名 等 各 项 信息 。 

【实例 20-1】 以 下 代码 为 BBS 系统 的 配置 文件 。 


01 <?php 

02 $db. host-"localhost"; // 主 机 名 
03 $db_user="root"; /用 户 名 
04 $db pass-"admin"; /用 户 密码 
05 $db name-"test"; /| 数据 库 名 
06 $table members-"members"; APR 
07 $table topic-"topic"; // 分 类 表 
08 $table posts-"posts"; IFR 
09 Slink=mysql_connect($db_host,$db_user,$db_pass); /连接 主机 
10 mysql_select_db($db_name,$link); /选择 数据 库 
um 


注意 : 配置 文件 中 的 内 容 可 以 根据 实际 情况 进行 修改 。 


20.2.2 ”安装 文件 的 创建 
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本 小 节 开 始 创建 安装 文件 。 该 文件 的 作用 是 : 先 给 用 户 一 个 界面 ， 让 用 户 完成 输入 相关 内 容 。 用 
户 输入 完毕 后 ， 在 后 台 执行 以 下 操作 : 分 别 创建 用 户 表 、 分 类 表 、 帖 子 表 ; 为 用 户 表 添加 用 户 输入 的 
管理 员 信息 、 为 分 类 表 添加 默认 分 类 、 为 帖子 表 添 加 默认 的 帖子 ， 给 出 用 户 相应 的 信息 。 

【实例 20-2】 以 下 代码 用 来 创建 安装 文件 。 


@ 
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实例 20-2: 安装 文件 
源码 路 径 光盘 \ 源 文件 20\20-2.php 


01 <?php 

02 echo "<html>"; 

03 echo "<head>"; 

04 echo "<title> 安 装 程序 </title>"; 

05 echo "</head>"; 

06 echo "<body>"; 

07 echo "<style>"; 

08 echo" ( 

09 padding: 0; 

10 margin: 0; 

11 ) 

12 body ( 

13 font-family: verdana, sans-serif; 
14 font-size: 10pt; 

15 background-color: &FFFFEE; 
16 padding: 25px Opx 25px Opx; 
17 ) 

18 a:link, a:active, a:visited ( 

19 color: #336699; 

20 text-decoration: underline; 
21 } 

22 a:hover { 

23 color: #7F0000 !important; 
24 text-decoration: none; 

25 } 

26 select option { 

2 padding-right: 3px; 

28 ) 

29 stcontent ( 

30 padding: Opx 25px 10px 25px; 
31 ) 

32 p, table, pre, h2, h3, ul, ol, dl ( 

33 margin: Opx Opx 15px Opx; 
34 ) 

35 p.important ( 

36 background-color: #EFDFBF; 
37 padding: 10px; 

38 font-size: 8pt; 

39 ) 

40 p#submit, pZsubmit input ( 

41 text-align: center; 

42 font-weight: bold; 

43 ) 

44 p#submit input ( 

45 padding: 5px; 

46 H 

47 h2( 
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48 color: #336699; 

49 font-weight: normal; 

50 font-size: 14pt; 

51 border-bottom: 1px solid silver; 
52 ) 

53 h3( 

54 color: #333; 

55 font-weight: bold; 

56 font-size: 10pt; 

57 ) 

58 ul, ol ( 

59 margin-left: 35px; 

60 ) 

61 di dt ( 

62 font-weight: bold; 

63 color: #333; 

64 ) 

65 di dd ( 

66 margin-left: 35px; 

67 margin-bottom: 5px; 

68 ) 

69 table ( 

70 background-color::£000000; 

71 border-collapse: collapse; 

72 margin-left: 0; 

73 margin-right: 0; 

74 ) 

5 table th, table td ( 

76 padding: 5px; 

77 ) 

78 td( 

79 background-color:s£cccc99; 

80 ) 

81 table th ( 

82 text-align: left; 

83 color: #336699; 

84 ) 

85 table td.title ( 

86 width: 135px; 

87 Ya 

88 echo "</style>"; 

89 if(!$ POST['admin']) 

90 { 

91 echo "<script language=\"javascript\">"; 
92 echo "function juge(theForm)"; 
93 echo "{"; 

94 echo "if (theForm.admin.value == Y"): 
95 echo "(*; 

96 echo "alert(\" 请 输入 管理 员 名 称 ! \");"; 
97 echo "theForm.admin.focus();"; 
98 echo "return (false);"; 


// 如 果 没 有 默认 参数 ， 显 示 HTML 
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99 echo "^ 

100 echo "if (theForm.pass.value == VY)"; 

101 echo "(*; 

102 echo "alert(\" 请 输入 管理 员 密码 ! Vy 

103 echo "theForm.pass.focus();"; 

104 echo "return (false);"; 

105 echo "}"; 

106 echo "if (fheForm.pass.value.length < 8 )"; 

107 echo "(*; 

108 echo "alert(\" 密 码 至 少 要 8 fit! V"; 

109 echo "theForm.pass.focus();"; 

110 echo "return (false);"; 

111 echo "j"; 

112 echo "if (theForm.re pass.value !-theForm.pass.value)"; 
113 echo "(*; 

114 echo "alert(\" 确 认 密码 与 密码 不 一 致 ! \");"; 

115 echo "theForm.re pass.focus();"; 

116 echo "return (false);"; 

117 echo "}"; 

118 echo "if (theForm.nickname.value == \"\")"; 

119 echo "(*; 

120 echo "alert(\" 请 输入 昵称! Vy" 

121 echo "theForm.nickname.focus();"; 

122 echo "return (false);"; 

123 echo "}"; 

124 echo "if (theForm.pre.value == VY)"; 

125 echo "("; 

126 echo "alert(\" 请 输入 表 前 缀 ! \");"; 

127 echo "theForm.pre.focus();"; 

128 echo "return (false);"; 

129 echo "}"; 

130 echo "}"; 

131 echo "</script>"; 

132 echo "<center>"; 

133 echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">"; 
134 echo "<form method=\"post\" action=\"$PATH_INFO\" onsubmit=\"return juge(this)\">"; 
135 echo "<tr>"; 

136 echo "<td colspan=\"2\" align=\"center\"><font size=\"5px\"> 安 装 论坛 </font></td>"; 
137 echo "</tr>"; 

138 echo "<tr>"; 

139 echo "<td> 管 理 员 : 〈 后 台 登 录 ) </td>"; 

140 echo "<td><input type=\"text\" name=\"admin\"></td>"; 
141 echo "</tr>"; 

142 echo "<tr>"; 

143 echo "<td> 管 理 员 密码 : 〈 不 小 于 8 位 ) </td>"; 

144 echo "<td><input type=\"password\" name=\"pass\" size=\"21\"></td>"; 
145 echo "</tr>"; 

146 echo "<tr>"; 

147 echo "<td> 确 认 密码 : </td>"; 

148 echo "<td><input type=\"password\" name=\"re_pass\" size=\"21\"></td>"; 
149 echo "</tr>"; 


431 


PHP 网 络 编程 技术 详解 


150 echo "<tr>"; 

151 echo "<td> 3851 E-mail: CHE) </td>"; 

152 echo "<td><input type=\"text\" name=\"email\"></td>"; 
153 echo "</tr>"; 

154 echo "<tr>"; 

155 echo "<td> 管 理 员 昵称 : (MAER) </td>"; 

156 echo "<td><input type=\"text\" name=\"nickname\"></td>"; 
157 echo "</tr>"; 

158 echo "<tr>"; 

159 echo "<td> 表 的 前 缀 : </td>"; 

160 echo "<td><input type=\"text\" name=\"pre\" value=\"bbs_\"></td>"; 
161 echo "</tr>"; 

162 echo "<tr>"; 

163 echo "<td colspan=\"2\"><center>"; 

164 echo "<input type=\"submit\" value=\" F —27 V"; 

165 echo "<input type=\"reset\" value=\" 重 新 填 \">"; 

166 echo "</center></td>"; 

167 echo "</tr>"; 

168 echo "</form>"; 

169 echo "</table>"; 

170 echo "</center>"; 

171 echo "</body>"; 

172 echo "<html>"; 

173 } 

174 else // 如 果 有 POST 参数 执行 操作 
175 t 

176 $name-$ POSI[admin]; // 获 得 参数 
177 $password=md5($_POST[pass]); /获得 密码 ， 并 使 用 MD5 进行 加 密 操作 
178 $nickname=$_POST[nickname']; 

179 $email=$_POST[email]; 

180 $pre-$ POST[preT; 

181 require "20-1.php"; 

182 $table members-$pre.$table members; 

183 $table topic-$pre.$table topic; 

184 $table posts-$pre.$table posts; 

185 $ip-$ SERVER[REMOTE ADDRT; 

186 $time-date("Y 4 m H d RH"); 

187 $time2-date("G: i: s"); 

188 $sql-"create table $table members( 

189 id int(5) not null auto increment primary key, 

190 name varchar(12) not null, 

191 password varchar(40) not null, 

192 nickname varchar(12) not null, 

193 sex enum(boy' girl") not null default 'boy', 

194 email varchar(80) not null, 

195 photo varchar(80) not null, 

196 q name varchar(200) not null, 

197 post num int(5) not null, 

198 reg date varchar(20) not null, 

199 admin int(1) not null default 'O', 

200 level int(5) not null, 
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201 other varchar(200) not null 

202 y 

203 mysql query(Ssql,Slink) or die(mysql. error()); /发 送 创建 member 表 的 SQL 请 求 
204 $sql="create table $table topic( 

205 id int(5) not null auto increment primary key, 

206 p. id int(5) not null, 

207 topic name varchar(12) not null, 

208 topic description varchar(80) not null, 

209 last post id int (5) not null, 

210 post count int(5) not null, 

211 post m count int(5) not null, 

212 other varchar(200) not null 

213 Y: 

214 mysql_query($sql,$link) or die(mysql_error()); /发 送 创建 topic 表 的 SQL 请 求 
215 $sql="create table $table posts( 

216 id int(5) not null auto increment primary key, 

217 topic id int(5) not null, 

218 re id int(5) not null, 

219 poster id int(5) not null, 

220 poster ip varchar(23) not null, 

221 poster varchar(12) not null, 

222 title varchar(40) not null, 

223 content text not null, 

224 view count int(5) not null, 

225 re count int(5) not null, 

226 post time varchar(40) not null, 

227 post re time varchar(40) not null, 

228 other varchar(200) not null 

229 y; 

230 mysql! query(Ssql,Slink) or die(mysql error()); /发 送 创建 posts 表 的 SQL 请 求 
231 $sql="insert into $table topic(p_id,topic_name,topic_description)values('0', 默 认 主 类 别 1',' 系 统 
创建 的 默认 主 类 别 ")"; 

232 mysql_query($sql, $link) or die(mysql_error()); // 发 送 添 加 默认 主 分 类 的 SQL 请 求 
233 $sql-"insert into $table topic(p id,topic name,topic description,last post id,post count, post 
m count)values('1', RUDRA, RA 6 B9 BR 1A 43 28839 1,147)"; 

234 mysql! query($sql,Slink) or die(mysql error()); // 发 送 添加 默认 子 分 类 的 SQL 请 求 
235 $sql="insert into ^ $table members(name,password,nickname,email,post num,reg date,admin) 
values('$name','$password','$nickname','$email','1','Stime','3')"; 

236 mysql_query($sql,$link) or die(mysgl error()); /发 送 添加 管理 员 信息 的 SQL 请 求 
237 $sql="insert into  $table posts(topic id,poster id,poster ip,poster,title,content,post time,post re - 
time)values('2,"1','$ip','$name',' 第 一 条 测试 信息 ',' 测 试 发 帖 是 否 有 效 ','$timeS$time2','$time$time2')"; 

238 mysql_query($sql, $link) or die(mysql error()); // 发 送 添 加 发 帖 的 SQL 请 求 

239 $sql="update $table topic set post_count="1',post_m_count="1' where id='2"; 

240 mysql_query($sql, $link) or die(mysql_error()); // 发 送 更 改 分 类 表 的 SQL 请 求 

241 $fp=fopen("20-1.php","w+"); // 将 更 新 过 的 数据 写 入 配置 文件 
242 fputs($fp,"<?"); 

243 fputs($fp,"\$db_host=\"localhost\";"); 

244 fputs($fp,"\$db_user=\"root\";"); 

245 fputs($fp,"\$db_pass=\"\";"); 

246 fputs($fp,"\$db_name=\"test\";"); 

247 fputs($fp,"\$table_members=\"$table_members\";"); 
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248 fputs($fp,"$table topic=\"$table topic"; 

249 fputs($fp," Stable posts-'$table posts"); 

250 fputs($fp,"$linkzmysql connect($db host|$db user, $db pass);"); 
251 fputs($fp,"mysql! select db($db name, W$link);"); 

252 fputs($fp, ?> ); 

253 fclose($fp); 

254 echo "<center>"; 

255 echo "<table width=\80%\ cellpadding=\"1\" cellspacing=\"1\" alignzV center" bgcolor= 
\"#000000\">"; 

256 echo "<tr bgcolor=\"#cccc99\">"; 

257 echo "<td align=\"center\"><font size=\"5px\"> 安 装 论坛 </font></td>"; 
258 echo "</tr>"; 

259 echo "<tr bgcolor=\"#cccc99\">"; 

260 echo "<td align=\"center\"><font size=\"3px\"> 成 功 安装 ! </font></td>"; 
261 echo "</tr>"; 

262 echo "<tr bgcolor=\"#cccc99\">"; 

263 echo "<td align=\"center\"><font size=\"3px\"> 删 除 该 文件 ， 以 减少 潜在 危险 ! </font></td>"; 
264 echo "</tr>"; 

265 echo "<tr bgcolor=\"#cccc99\">"; 

266 echo "<td align=\"center\"> 点 <a href=\"20-3.php\"> 这 里 </a> 进 入 </td>"; 
267 echo "</tr>"; 

268 echo "</table>"; 

269 echo "</center>"; 

270 echo "</body>"; 

271 echo "«/html»"; 

272 ) 

273 ?> 


说 明 : 安装 文件 的 作用 是 创建 一 个 高 权限 的 管理 员 并 且 创 建 所 需要 的 数据 表 。 


在 PHP 运行 环境 下 执行 该 PHP 文件 ， 以 完成 论坛 程序 所 需 用 户 表 的 创建 。 首 次 执行 该 PHP 文件 ， 
执行 结果 如 图 20.1 所 示 。 


CEES) 


@ ET 


安装 论坛 
管理 员 ，〔 后 台 登 录 ) C 
管理 员 密 码 ，〈 不 小 于 8 位 ) | 
确认 密码 ， 
| 管理 员 E-mail， (可 选 ) 
PAN: (HELT [一 |] 
EXE [pos 
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图 20.1 首次 运行 安装 文件 的 执行 结果 
按照 要 求 填 入 全 部 信息 。 其 中 表 的 前 组 一 项 指 在 建立 表 时 为 了 避免 与 已 经 存在 的 表 出 现 重 名 现象 
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为 表 设 置 的 前 级 项 。 全 部 填写 完毕 单 击 “ 下 一 步 ”按钮 ， 将 出 现 如 图 202 所 示 的 执行 结果 。 


xis] 


成 功 安装 ! 
弄 除 该 文件 ， 以 诚 少 清 在 危险 ! 
点 这 里 进入 


图 20.2 安装 完成 执行 结果 
执行 过 这 一 步 操作 后 ， 系 统 所 需要 的 3 个 表 都 已 经 成 功 创建 完毕 ， 并 且 还 为 每 个 表 添 加 了 相应 项 
目 。 为 用 户 表 添 加 了 系统 管理 员 ， 为 分 类 表 添 加 了 默认 主 分 类 与 子 分 类 ， 为 发 帖 表 添加 了 第 一 条 帖子 。 
系统 安装 程序 执行 过 后 ， 准 备 工作 就 算是 全 部 完成 了 。 接 下 来 就 是 每 个 功能 模块 的 具体 实现 了 。 
从 20.3 节 开 始 ， 就 通过 具体 的 代码 来 实现 论坛 的 具体 模块 。 


203 用户 注册 与 登录 


论坛 与 用 户 是 密 不 可 分 的 ， 用 户 的 多 少 是 评判 一 个 论坛 人 气 的 重要 标准 之 一 。 一 个 搞 得 好 的 论坛 
往往 注册 用 户 达到 多 少 万 ， 而 一 个 比较 差 的 论坛 的 注册 用 户 往往 很 少 。 既 然 需要 注册 用 户 ， 就 要 提供 
给 用 户 一 个 友好 的 注册 与 登录 界面 。 本 节 就 来 创建 用 户 的 注册 与 登录 页 。 


20.3.1 用 户 注 册页 


GE 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 20 章 \ 用 户 注册 页 .wmv 

注册 新 用 户 页 提供 给 用 户 一 个 表单 ， 以 便 用 户 输入 相关 内 容 ， 包 括 必要 的 用 户 名 、 用 户 密码 、 用 
户 昵称 、 性 别 、 电 子 信箱 、 选 择 图 像 、 输 入 发 帖 签 名 等 ， 其 中 的 用 户 名 、 用 户 密码 、 用 户 昵称 为 必 
填 项 。 

【实例 20-3】 以 下 为 用 户 注册 页 代码 。 


re t 实例 20-3: 用 户 注册 页 
源码 路 径 : 光盘 \ 源 文件 20\20-3.php 


01 <?php 

02 echo "<html>"; 

03 echo "<head>"; 

04 echo "<title> 注 册 新 用 户 </title>"; 
05 echo "</head>"; 

06 echo "<body>"; 

07 echo "<style>"; 

08 echo" ( 

09 padding: 0; 

10 margin: 0; 


9) 
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11 ) 

12 body ( 

13 font-family: verdana, sans-serif; 
14 font-size: 10pt; 

15 background-color: &FFFFEE; 
16 padding: 25px Opx 25px Opx; 
17 ) 

18 a:link, a:active, a:visited ( 

19 color: #336699; 

20 text-decoration: underline; 

21 ) 

20 a:hover ( 

23 color: #7F0000 !important; 

24 text-decoration: none; 

25 ) 

26 select option ( 

27 padding-right: 3px; 

28 ) 

29 stwrapper ( 

30 width: 650px; 

31 border: 1px solid silver; 

32 margin-left: auto; 

33 margin-right: auto; 

34 background-color: #EFEFEF; 
35 background-image: url(gfx/bg.png); 
36 background-repeat: repeat-x; 
37 ) 

38 *twrapper h1 ( 

39 height: 90px; 

40 line-height: 90px; 

41 background-image: url(gfx/logo.png); 
42 background-repeat: no-repeat; 
43 background-position: top right; 
44 padding: Opx 25px Opx 25px; 
45 font-weight: normal; 

46 font-size: 24pt; 

47 letter-spacing: -2px; 

48 word-spacing: 5px; 

49 color: #336699; 

50 ) 

51 stcontent ( 

52 padding: Opx 25px 10px 25px; 
53 ) 

54 p, table, pre, h2, h3, ul, ol, dl ( 

55 margin: Opx Opx 15px Opx; 

56 ) 

57 p.important ( 

58 background-color: #EFDFBF; 
59 padding: 10px; 

60 font-size: 8pt; 

61 ) 
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62 p#submit, p£submit input ( 
63 text-align: center; 

64 font-weight: bold; 

65 ) 

66 p#submit input ( 

67 padding: 5px; 

68 } 

69 h2{ 

70 color: #336699; 

71 font-weight: normal; 
72 font-size: 14pt; 

73 border-bottom: 1px solid silver; 
74 ) 

75 h3( 

76 color: #333; 

77 font-weight: bold; 

78 font-size: 10pt; 

79 ) 

80 ul, ol ( 

81 margin-left: 35px; 

82 ) 

83 di dt ( 

84 font-weight: bold; 

85 color: #333; 

86 ) 

87 di dd ( 

88 margin-left: 35px; 

89 margin-bottom: 5px; 
90 ) 

91 table ( 

92 background-color:$£000000; 
93 border-collapse: collapse; 
94 margin-left: 0; 

95 margin-right: 0; 

96 ) 

97 table th, table td ( 

98 padding: 5px; 

99 ) 

100 td( 

101 background-color:s£cccc99; 
102 ) 

103 table th ( 

104 text-align: left; 

105 color: #336699; 

106 ) 

107 table td.title { 

108 width: 135px; 

109 jus 

110 echo "</style>"; 

111 if$ POST[user]) /如 果 没 有 默认 参数 ， 显 示 HTML 
112 { 
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113 echo "<script language=\"javascript\">"; 

114 echo "function juge(theForm)"; 

115 echo "(*; 

116 echo "if (theForm.user.value == VY)"; 

[17 echo "f"; 

118 echo "alert(\" 请 输入 注册 用 户 名 ! Vy 

119 echo "theForm.user.focus();"; 

120 echo "return (false);"; 

121 echo "j"; 

122 echo "if (theForm.pass.value == \"\")"; 

123 echo "(*; 

124 echo "alert(\" 请 输入 用 户 密码 ! Vy": 

125 echo "theForm.pass.focus();"; 

126 echo "return (false);"; 

127 echo "]"; 

128 echo "if (theForm.pass.value.length < 8 )"; 

129 echo "(*; 

130 echo "alert(\" 密 码 至 少 要 8 位 ! V" 

131 echo "theForm.pass.focus();"; 

132 echo "return (false);"; 

133 echo "}"; 

134 echo "if (theForm.re pass.value !-theForm.pass.value)"; 
135 echo "(*; 

136 echo "alert(\" 确 认 密码 与 密码 不 一 致 !\");"; 

137 echo "theForm.re pass.focus();"; 

138 echo "return (false);"; 

139 echo "j"; 

140 echo "if ((fheForm.nickname.value == VY)": 

141 echo "(*; 

142 echo "alert(\" 请 输入 昵称! Vy" 

143 echo "theForm.nickname.focus();"; 

144 echo "return (false);"; 

145 echo "}"; 

146 echo "}"; 

147 echo "function s photo(the)"; 

148 echo "("; 

149 echo "document.img.src-'images/"*the.photo.value-*' .bmp*;"; 
150 echo "}"; 

151 echo "</script>"; 

152 echo "<center>"; 

153 echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">"; 
154 echo "<form method=\"post\" action=\"$PATH_INFO\" onsubmit=\"return juge(this)\">"; 
155 echo "<tr>"; 

156 echo "<td colspan=\"2\" align=\"center\"><font size=\"5px\"> 注 册 新 用 户 </font></td>"; 
157 echo "</tr>"; 

158 echo "<tr>"; 

159 echo "<td> 用 户 名 : 〈 后 台 登 录 ) </td>"; 

160 echo "<td><input type=\"text\" name=\"user\"></td>"; 

161 echo "</tr>"; 

162 echo "<tr>"; 

163 echo "<td> 用 户 密码 : 〈 不 小 于 8 位 ) </td>"; 

164 echo "<td><input type- password" name=\"pass\" size=\"21\"></td>"; 
165 echo "</tr>"; 
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166 echo "<tr>"; 

167 echo "<td> 确 认 密码 : </td>"; 

168 echo "<td><input type=\"password\" name=\"re_pass\" size=\"21\"></td>"; 
169 echo "</tr>"; 

170 echo "<tr>"; 

171 echo "<td> 用 户 E-mail: (CAR) </td>"; 

172 echo "<td><input type=\"text\" name=\"email\"></td>"; 

173 echo "</tr>"; 

174 echo "<tr>"; 

175 echo "<td> A ARER: (MARR) </td>"; 

176 echo "<td><input type=\"text\" name=\"nickname\"></td>"; 
177 echo "</tr>"; 

178 echo "<tr>"; 

179 echo "<td> 选 择 性 别 : </td>"; 

180 echo "«td»"; 

181 echo "<input type-l'radio" name=\"sex\" value=\"boy\" checked? S"; 
182 echo "<input type=\"radio\" name=\"sex\" value=\"gir\"> 女 "; 
183 echo "</td>"; 

184 echo "</tr>"; 

185 echo "<tr>"; 

186 echo "<td> 选 择 图 像 : </td>"; 

187 echo "<td>"; 

188 echo "<select name=\"photo\" size=\"1\" onchange=\"s_photo(this.form)\">"; 
189 for($i=1;$i<21;$i++) 

190 ( 

191 echo "<option value=".$i.">".$i."</option>";; 

192 } 

193 echo "</select>"; 

194 echo "<img src=\"images/1.bmp\" name=\"img\">"; 

195 echo"</td>"; 

196 echo "</tr>"; 

197 echo "<tr>"; 

198 echo "<td colspan=\"2\"><center>"; 

199 echo "<input type=\"submit\" value=\" 下 一 步 \">"; 

200 echo "<input type=\"reset\" value=\" 重 新 填 \">"; 

201 echo "</center></td>"; 

202 echo "</tr>"; 

203 echo "</form>"; 

204 echo "</table>"; 

205 echo "</center>"; 

206 echo "</body>"; 

207 echo "<html>"; 

208 } 


以 上 为 用 户 注册 的 前 台 显示 页 面 。20.3.2 小 节 来 介绍 用 户 注册 的 后 台 处 理 。 
20.3.2 ”注册 的 后 台 处 理 


GEH 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 20 章 \ 注 册 的 后 台 处 理 .wmv 


注册 的 后 台 处 理 先 要 获取 用 户 输入 的 各 项 内 容 ， 其 中 登录 用 户 名 是 最 为 重要 的 一 项 。 因 为 该 项 要 
求 具 有 唯一 性 ， 即 同一 个 论坛 不 能 有 同名 用 户 的 出 现 ， 所 以 要 对 用 户 输入 的 用 户 名 进行 审核 。 这 就 会 
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出 现 两 种 情况 : 如 果 已 经 存在 同名 用 户 ， 则 给 出 错误 提示 ， 并 要 求 用 户 重新 输入 新 的 用 户 名 ; 如 果 没 
有 同名 用 户 ， 则 把 用 户 输入 信息 作为 一 条 新 的 记录 添加 到 用 户 表 中 。 
下 面 给 出 具体 的 处 理 过 程 ， 请 参看 如 下 代码 : 


209 else // 如 果 有 默认 参数 ， 执 行 操作 

210 { 

211 $user=$_POST[user]; 1/ 获取 用 户 输入 数据 

212 $pass-md5($ POST[pass"]; /获取 密码 并 进行 MD5 处 理 

213 $email=$_POST[email]; 

214 $nickname-$ POST[nicknameT; 

215 $sex-$ POST[sexT; 

216 Stime-date("Y 4 m H d R"); /获取 当前 时 间 

217 Sphoto-$ POST[photo']." bmp"; 

218 require "20-1.php"; // 调 用 配置 文件 

219 $sql="select id from $table user where username='$user"; 

220 $result-mysql! query(Ssql,Slink); /发 送 查 找 用 户 名 的 SQL 请 求 

221 $nums-mysq| num rows(Sresult); IRRERAR 

222 if($nums!=0) // 如 果 结果 不 等 于 0 

223 { 

224 echo "注册 的 用 户 名 $user 已 经 存在 ! <p>"; — // 给 出 相应 提示 

225 echo "请 点 <a href=# onclick=history.go(-1)> 这 里 </a> 返 回 ， 重 新 输入 新 的 用 户 名 ! "; 

226 exit(); // 退 出 所 有 PHP 操作 

227 H 

228 else // 如 果 结果 为 0 

229 ( 

230 $sql-"insert into $table members(name,password,email,nickname,sex,photo,reg date) 

values('Suser','$pass','Semail'$nickname','$sex','Sphoto''Stime")"; 

231 mysql query($sql,Slink); /发 送 插入 记录 的 SQL 请 求 

232 echo "新 用 户 $user 注册 成 功 ! <p>"; // 显 示 成 功 提示 

233 echo "点 <a href=20-4.php> 这 里 </a> 进 行 登录 !"; 

234 } 

235 } 

236 ?> 

把 以 上 代码 与 20.3.1 小 节 的 代码 结合 起 来 保存 为 20-3.php, 然后 在 PHP 运行 环境 下 执行 该 PHP X 
件 ， 首 次 运行 会 出 现 如 图 20.3 所 示 的 执行 结果 。 
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注册 新 用 户 
RPA GER)  — 
用 户 密码 ，( 不 小 8 位) [| 
[s 
BPEmah (TA) — | 
BEER GET) [ —  — 


选择 性 别 : (Up d 
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图 20.3 注册 新 用 户 执行 结果 
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按照 要 求 输入 相应 的 用 户 名 、 用 户 密码 、 确 认 密码 、 电 子 信箱 、 用 户 昵称 及 选择 相应 的 图 像 后 单 
上 i“ 下 一 步 ”按钮 。 如 果 用 户 名 已 经 存在 ， 则 会 出 现 如 图 20.4 所 示 的 提示 。 
如 果 输 入 的 用 户 名 是 没有 注册 过 的 ， 则 会 出 现 如 图 20.5 所 示 的 执行 结果 。 
a C 


E 
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&1006 = 
图 20.4 注册 用 户 时 用 户 名 重复 执行 结果 图 20.5 注册 用 户 时 注册 成 功 执行 结果 
这 时 由 于 并 不 存在 重 名 用 户 ， 所 以 允许 用 户 注册 ， 并 将 用 户 的 输入 信息 写 入 用 户 表 中 ， 此 用 户 便 
可 登录 系统 了 。 
用 户 的 注册 及 注册 处 理 就 介绍 到 这 里 。20.3.3 小 节 将 讲解 用 户 的 登录 与 登录 处 理 。 


20.3.3 ”用户 登录 页 面 


GÈ 知识 点 讲解 :光盘 \ 视 频 讲 解 \ 第 20 章 \ 用 户 登录 页 面 .wmv 
用 户 信息 添加 进 用 户 表 后 ， 就 要 让 用 户 能 够 正确 登录 到 系统 中 了 。 相 比 用 户 注册 ， 用 户 登录 要 简 
单一 些 。 只 需要 给 出 用 户 名 及 用 户 密码 就 可 以 了 。 如 果 用 户 输入 信息 与 库 中 存在 的 一 致 ， 则 把 用 户 名 
及 相关 信息 存 为 Cookie 变量 。 
技巧 : Cookie 在 用 户 登录 时 也 可 以 为 用 户 提供 一 个 现在 比较 流行 的 Cookie 保 存 时 间 选 择 。 这 样 就 可 以 
让 用 户 自由 选择 Cookie 的 保留 时 间 。 如 果 是 在 公用 计算 机 或 者 网 吧 使 用 论坛 系统 ， 就 设 为 最 短 
时 效 即 关闭 浏览 器 清除 Cookie; 如 果 是 在 私有 计算 机 或 者 家 里 使 用 ， 则 可 以 设 为 一 个 月 或 一 年 
等 更 长 的 时 间 。 


【实例 20-4】 以 下 为 用 户 登录 页 面 的 代码 。 


re 实例 20-4: 用 户 登录 页 面 
源码 路 径 : 光盘 \ 源 文件 20\20-4.php 


01 <?php 

02 i$ POST[user]) // 和 如果 没 有 默认 参数 ， 显 示 HTML 
03 { 

04 echo "<html>"; 

05 echo "<head>"; 

06 echo "<title> 注 册 用 户 登 录 </title>"; 
07 echo "</head>"; 

08 echo "<body>"; 

09 echo "<style>"; 

10 echo "*( 

11 padding: 0; 

12 margin: 0; 

13 n 

14 body ( 
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15 
16 
17 
18 
19 
20 
21 
22 
23 
24 
25 
26 
27 
28 
29 
30 
31 
32 
33 
34 
35 
36 
37 
38 
39 
40 
41 
42 
43 
44 
45 
46 
47 
48 
49 
50 
51 
52 
53 
54 
55 
56 
57 
58 
59 
60 
61 
62 


font-family: verdana, sans-serif; 
font-size: 10pt; 
background-color: &FFFFEE; 
padding: 25px Opx 25px 0px; 


H 

a:link, a:active, a:visited ( 
color: #336699; 
text-decoration: underline; 

H 

a:hover { 
color: #7F0000 !important; 
text-decoration: none; 

J 


select option ( 
padding-right: 3px; 

) 

p, table, pre, h2, h3, ul, ol, dl ( 
margin: Opx Opx 15px Opx; 


i 

h2{ 
color: #336699; 
font-weight: normal; 
font-size: 14pt; 
border-bottom: 1px solid silver; 

y 

h3( 
color: #333; 
font-weight: bold; 
font-size: 10pt; 

) 

ul, ol ( 
margin-left: 35px; 

} 

table { 
background-color:#000000; 
border-collapse: collapse; 
margin-left: 0; 
margin-right: 0; 

Ü 

table th, table td ( 
padding: 5px; 

} 

td{ 
background-color:#cccc99; 

} 

table th { 
text-align: left; 
color: #336699; 

} 

table td.title { 
width: 135px; 
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66 Y 

67 echo "</style>"; 

68 echo "<script language-'javascript "7"; 

69 echo "function juge(theForm)"; 

70 echo "("; 

TÉ echo "if (theForm.user.value == Y)"; 

72 echo "(*; 

73 echo "alert(\" 请 输入 用 户 名 ! Vy" 

74 echo "theForm.user.focus();"; 

75 echo "return (false);"; 

76 echo "}"; 

ny. echo "if (theForm.pass.value == \"\")"; 

78 echo "(*; 

79 echo "alert(\'" 请 输入 用 户 密码 ! Vy"; 

80 echo "theForm.pass.focus();"; 

81 echo "return (false);"; 

82 echo "}"; 

83 echo "}"; 

84 echo "</script>"; 

85 echo "<center>"; 

86 echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">"; 
87 echo "<form method=\"post\" action=\"$PATH_INFO\" onsubmit=\"return juge(this)\">"; 
88 echo "<tr>"; 

89 echo "<td colspan=\"2\" align=\"center\"><font size=\"5px\"> 注 册 用 户 登录 </font></td>"; 
90 echo "</tr>"; 

91 echo "<tr>"; 

92 echo "<td> 用 户 名 : </td>"; 

93 echo "<td><input type=\"text\" namez- "user" » «/td»"; 
94 echo "</tr>"; 

95 echo "<tr>"; 

96 echo "<td> 用 户 密码 :</td>"; 

97 echo "<td><input type- password" name- pass!" size=\"21\"></td>"; 
98 echo "</tr>"; 

99 echo "<tr>"; 

100 echo "<td> 选 择 COOKIE 有 效 期 : </td>"; 

101 echo "<td>"; 

102 echo "<select name=\"cook_t\" size=\"1\">"; 

103 echo "<option value=\"1\"> 最 短 时 效 </option>"; 
104 echo "<option value=\"2\">1 天 </option>"; 

105 echo "<option value=\"3\">1 月 </option>"; 

106 echo "<option value=\"4\">1 年 </option>"; 

107 echo "</select>"; 

108 echo"</td>"; 

109 echo "</tr>"; 

110 echo "<tr>"; 

111 echo "<td colspan=\"2\"><center>"; 

112 echo "<input type=\"submit\" value" F —2V»"; 
113 echo "<input type=\"reset\" value=\" 重 新 填 \">"; 
114 echo "</center></td>"; 

115 echo "</tr>"; 

116 echo "</form>"; 


DUM LIT TI 


117 
118 
119 
120 
121 


) 


echo "</table>"; 
echo "</center>"; 
echo "</body>"; 
echo "<html>"; 


上 面 给 出 的 代码 是 用 来 显示 注册 用 户 登录 的 前 台 。20.3.4 小 节 为 读者 介绍 用 户 登录 的 后 台 处 理 。 
20.3.4 登录 出 错 及 处 理 


GE 知识 点 讲解 : 光盘 \ 视 频 讲 解 \ 第 20 章 \ 登 录 出 错 及 处 理 .wmv 

用 户 登 录 的 后 台 处 理 要 先 获取 用 户 输入 的 数据 , 最 主要 的 是 用 户 名 与 用 户 密码 两 项 。 然后 对 库 中 的 用 
户 数据 表 进 行 遍历 ， 判 断 有 没有 相应 的 用 户 存在 。 如 果 存 在 相应 的 用 户 则 把 用 户 名 写 入 Cookie 变量 ， 并 
根据 用 户 的 选择 为 Cookie 设置 生命 期 限 ， 显 示 登 录 成 功 的 提示 ， 或 者 直接 跳 转 到 论坛 的 首页 。 反 之 ， 如 
果 不 存 在 相应 的 用 户 或 者 用 户 密码 不 正确 则 给 出 错误 提示 ， 给 出 返回 上 页 的 链接 ， 让 用 户 再 次 输入 选择 。 

具体 处 理 过 程 请 参看 如 下 代码 : 


122 


else 


{ 


$user=$_POST[usen]; /获取 用 户 输入 参数 
$pass=md5($_POST[pass]); 
$cook t=$_ POSTI'cook t7; 
require "20-1.php"; 
$sql-"select id from $table members where name-'$user' and password-'$pass"'; 
$result»mysql query($sql,Slink) or die(mysql error(); — //&iX FH P^ 
$nums-mysql num rows(Sresult); /把 查找 记录 数 赋值 给 变量 
if($nums--0) // 如 果 记 录 数 为 0 显示 内 容 
{ 

echo "<html>"; 

echo "<head>"; 

echo "<title> 注 册 用 户 登录 </title>"; 

echo "</head>"; 

echo "<body>"; 

echo "<center>"; 

echo "<h2> 输 入 的 用 户 名 或 者 密码 错误 ! </h2>"; 

echo "<h3> 请 点 <a href=# onclick=history.go(-1)> 这 里 </a> 返 回 重新 输入 ! </h3>"; 


echo "</center>"; 
exit(); 
ne // 如 果 存 在 记录 的 处 理 
: if(Scook t==1) // 根 据 用户 选 择 注册 COOKIE 
setcookie("user","Suser"); /最 短 


} 
elseif($cook_t==2) 


setcookie("user","Suser",time()*60*60*24); IK 


154 
155 
156 
157 
158 
159 
160 

161 

162 
163 
164 
165 
166 
167 
168 
169 
170 
171 
172 
173 ) 
174 ?> 


#25 yose LS 


elseif($cook t--3) 
d 
setcookie("user","Suser" time()*60*60*24*30); II-R 


else 


1 
setcookie("user","Suser",time()*60*60*24*30*360); /一 年 


echo "<html>"; 

echo "<head>"; 

echo "<title> 注 册 用 户 登录 </title>"; 

echo "</head>"; 

echo "<body>"; 

echo "<center>"; 

echo "<h2> 用 户 ".$user." 登 录 成 功 ! </h2>"; 

echo "<h3> 两 秒 后 进入 论坛 主题 页 面 ! </h3>"; 

echo "<meta http-equiv=\"refresh\" content=\"2; url=20-5.php\">"; 
echo "</center>"; 


将 以 上 代码 与 20.3.3 小 节 所 列 的 用 户 登录 页 面 代码 结合 起 来 ， 保 存 为 20-4.php。 在 PHP 运行 环境 
下 执行 该 文件 ， 执 行 结果 如 图 20.6 所 示 。 

按照 要 求 输入 相应 的 用 户 名 、 用 户 密码 ， 单 击 “ 下 一 步 ”按钮 开始 进行 登录 。 如 果 输 入 的 用 户 名 
或 者 用 户 密码 错误 ， 则 会 出 现 如 图 20.7 所 示 的 出 错 提示 。 


Cees 
re 
注册 用 户 登录 
用 户 名 ， — =e 
用 户 密码 ， ER [€] ED 
SURCOOKERSUR, germ > | 输入 的 用 户 名 或 者 密码 错误 ! 
kz KI 
请 点 这 里 返回 重新 输入 ! 

aioo - | 100% 

图 20.6 用 户 登 录 页 面 执 行 结果 图 20.7 用 户 登 录 出 错 提示 


如 果 输 入 的 用 户 名 及 密码 是 库 中 已 经 存在 的 并 且 正 确 ， 登 录 程序 将 会 自动 跳 转 到 论坛 的 显示 首页 


20-5.php. 20.4 节 


就 来 着 手 编写 该 显示 首页 文件 。 


注意 : 由 于 当前 还 没有 编写 20-5.php 这 个 页 面 ， 所 以 应 该 会 出 现 无 法 找到 所 请 求 页 面 的 提示 。 


20.4 


论坛 的 表 创 于 


耸 坛 首页 、 主 论坛 、 分 论坛 显示 文件 的 创建 


lE 完 毕 ， 用 户 注册 登录 系统 也 都 完善 了 。 接 下 来 ， 就 开始 论坛 首页 、 主 论坛 、 分 论坛 


© 


KA aaa 


显示 页 面 文件 的 创建 。 
20.4.1 论坛 首页 显示 文件 的 创建 


GB 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 20 章 \ 论 坛 首 页 显示 文件 的 创建 .wmv 

论坛 首页 文件 是 整个 论坛 系统 中 最 为 重要 的 文件 。 通 常 的 论坛 首页 文件 有 以 下 作用 : 显示 用 户 是 
否 登 录 ， 如 果 用 户 已 经 登录 ， 则 显示 登录 用 户 名 ， 反 之 则 给 出 登录 链接 ;显示 所 有 主 分 类 及 其 所 属 的 
子 分 类 、 某 一 分 类 的 总 帖子 数 、 其 中 的 主题 数 、 最 后 发 帖 时 间 、 最 后 的 作者 、 最 后 一 条 帖子 的 标题 等 
内 容 ; 通常 还 会 在 下 方 给 出 当前 在 线 的 用 户 〈 由 于 本 章 所 介绍 的 BBS 系统 没有 设计 在 线 用 户 ， 所 以 没 
有 这 个 功能 ) 。 

【实例 20-5】 以 下 代码 为 论坛 首页 文件 代码 。 


实例 20-5: 论坛 首页 
源码 路 径 光盘 \ 源 文件 20\20-5.php 


01 <?php 

02 echo "<html>"; 

03 echo "<head>"; 

04 echo "<title> 论 坛 首 页 </title>"; 

05 echo "</head>"; 

06 echo "<body>"; 

07 echo "<style>"; 

08 echo "body ( 

09 font-family: verdana, sans-serif; 
10 font-size: 10pt; 

11 background-color: £FFFFEE; 
12 padding: 25px Opx 25px Opx; 
13 ) 

14 a:link, a:active, a:visited ( 

15 color: #0033ff; 

16 text-decoration: underline; 
17 ) 

18 a:hover ( 

19 color: #7F0000 !important; 
20 text-decoration: none; 

21 ) 

22 select option ( 

23 padding-right: 3px; 

24 ) 

25 p, table, pre, h2, h3, ul, ol, dl ( 

26 margin: Opx Opx 15px Opx; 
27 ) 

28 p.important ( 

29 background-color: £EFDFBF; 
30 padding: 10px; 

31 font-size: 8pt; 

32 ) 

33 p#submit, p#submit input ( 


34 
35 
36 
37 
38 
39 
40 
41 
42 
43 
44 
45 
46 
47 
48 
49 
50 
51 
52 
53 
54 
55 
56 
57 
58 
59 
60 
61 
62 
63 
64 
65 
66 
67 
68 
69 
70 
71 
72 
73 
74 
75 
76 
77 
78 
79 
80 
81 
82 
83 
84 
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text-align: center; 
font-weight: bold; 
j 
p#submit input ( 


padding: 5px; 

l 

h2( 
color: #336699; 
font-weight: normal; 
font-size: 14pt; 
border-bottom: 1px solid silver; 

} 

h3{ 
color: #333; 
font-weight: bold; 
font-size: 10pt; 

} 

ul, ol ( 
margin-left: 35px; 

) 

di dt ( 
font-weight: bold; 
color: #333; 

) 

di dd ( 
margin-left: 35px; 
margin-bottom: 5px; 

) 

table ( 
background-color:$£000000; 
border-collapse: collapse; 
margin-left: 0; 
margin-right: 0; 

H 

table th, table td ( 
padding: 5px; 

} 

td{ 
background-color:#ddffff; 

} 

table th ( 
text-align: left; 
color: #336699; 

} 

table td.title { 
width: 135px; 

Yi 


echo "</style>"; 

echo "<center>"; 

echo "<table width=\"80%\" cellpadding-V" 1 cellspacing=\"1\">"; 
echo "<tr>"; 
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85 echo "<td>"; 

86 echo "<center><h2> 论 坛 首页 </h2></center>"; 

87 echo "</td>"; 

88 echo "</tr>"; 

89 echo "</table>"; 

90 echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">"; 

91 echo "<tr>"; 

92 echo "<td>"; 

93 if(l$ COOKIE[user]) // 如 果 没有 用 户 登录 ， 显 示 登 录 链 接 
94 { 

95 echo "<a href=\"20-4.php\"> 用 户 登录 </a>"; 

96 } 

97 else // 如 果 用 户 已 经 登录 ， 显 示 登 录用 户 名 
98 { 

99 require "20-1.php"; 

100 $sql-"select id from $table members where name-'$ COOKIE[user]"; 

101 S$resultzmysq! query($sql,Slink)); 

102 $rows-mysql fetch array(Sresult); 

103 echo "登录 用 户 : <a href=20-14.php?id=".$rows[0].">".$_COOKIE['user]."</a>"; 

104 } 

105 echo "</td>"; 

106 echo "</tr>"; 

107 echo "</table>"; 

108 echo "<table width=\"80%\" cellpadding- V1 cellspacing=\"1\">"; 

109 echo "<tr>"; 

110 echo "<td> 论 坛 名 称 </td><td> 论 坛 介绍 </td><td> 帖 子 数量 </td><td> 主 题 数 量 </td><td> 最 后 帖子 标题 
</td><td> 最 后 帖子 回复 时 间 </td>"; 

111 require "20-1.php"; 

112 $sql="select * from $table topic where p_id=0"; // 人 遍历 帖子 种 类 表 显 示 主 论坛 

113 $result=mysql_query($sql, $link) or die(mysql error()); 

114 while($rows=mysql_fetch_array(S$result)) 

115 { 

116 echo "«tr»"; // 显 示 主 论坛 的 标题 及 其 介绍 

117 echo "<td colspan=\"6\"><a href-V20-6.php?id-" Srows['id'].""»".$rows[topic name')."</a> : 
".$rows[topic description']."«/td»"; 

118 echo "</tr>"; 

119 $temp2-$rows['id']; 

120 $sql2-"select * from Stable topic where p id-'$temp2"; /遍历 种 类 表 显示 主 论坛 下 的 分 论坛 
121 $result2=mysql_query($sql2,$link) or die(mysql error()); 

122 while($rows2=mysql_fetch_array($result2)) /显示 分 论坛 的 各 项 信息 

123 { 

124 echo "<tr>"; 

125 echo "<td><a href220-7.php?id-".$rows2[id].""»".$rows2['topic name7."«/a»«/td»"; 
126 echo "«td»".$rows2['topic description']."«/td?"; 

127 echo "«td»".$rows2['post count]."«/td»"; 

128 echo "«td»".$rows2['post m count"]."«/td»"; 

129 $sql3-"select id,title,post re time from $table posts where id-'$rows2[last post id)"; 
130 $result32mysql! query($sql3,Slink) or die(mysql error()); 

131 $rows3-mysql fetch array(Sresult3); /显示 最 后 一 条 帖子 的 相关 信息 
132 echo "<td><a href-"20-8.php?id-" $rows3['id]."»".$rows3[title']."«/a» «/td»"; 

133 echo "«td»".$rows3['post re time']."«/td»"; 


e. 
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134 echo "</tr>"; 

135 d 

136 echo "<tr><td colspan=\"6\">&nbsp;</td></tr>"; 
137 } 


138 echo "</table>"; 
139 echo "</center>"; 
140 echo "</body>"; 
141 echo "</html>"; 


注意 : 由 于 系统 在 创建 时 已 经 创建 了 默认 的 主 论坛 和 分 论坛 ( 详 见 20.2.2 小 节 ) ， 所 以 目前 显示 的 只 有 
1 个 默认 的 主 论坛 与 其 下 的 一 个 分 论坛 。 


执行 结果 如 图 20.8 所 示 。 
~ eek) 
Qe: Jle heps//localhosy/20-5.php Dr Ò | eios x| | xr (9i 
论坛 首页 
登录 用 户 ，admin 
论坛 名 称 ”论坛 介绍 帖子 数量 主题 数量 最 后 帖子 标题 ”最 后 帖子 回复 时 间 


默认 主 夫 别 1， 系 统 创建 的 默认 主 关 别 
默认 分 类 别 系统 创建 的 默认 分 类 别 1 1 FAMAS 2013505816812. 17. 27 


图 20.8 论坛 首页 文件 首次 执行 结果 
20.4.2” 主 论坛 显示 文件 的 创建 


CÈ 知识 点 讲解 :光盘 \ 视 频 讲 解 \ 第 20 章 \ 主 论坛 显示 文件 的 创建 .wmv 

主 论坛 是 论坛 分 类 数据 中 一 种 比较 特殊 的 类 型 ， 它 代表 着 论坛 的 一 级 分 类 ， 在 它 的 下 面 还 有 更 详 
细 的 二 级 分 类 ， 做 这 样 的 划分 是 为 了 更 详细 地 划分 论坛 结构 。 例 如 ， 一 个 普通 的 论坛 可 能 包括 技术 区 、 
娱乐 区 等 内 容 , 其 中 的 技术 区 、 娱 乐 区 就 相当 于 主 论坛 。 技 术 区 里 可 能 会 划分 为 PHP 编程 区 、JavaScript 
编程 区 、MySQL 数据 库 编程 区 等 二 级 分 类 ; 娱乐 区 也 可 能 会 分 为 灌水 区 、 贴 图 区 、 音 乐 电影 区 等 二 级 
分 类 。 

因为 论坛 有 这 样 的 多 级 分 类 划分 ， 所 以 显示 主 论坛 及 其 下 的 分 论坛 是 很 有 必要 的 。 下 面 就 来 介绍 
如 何 用 PHP 代码 来 显示 主 论坛 。 

【实例 20-6】 以 下 为 主 论坛 显示 文件 代码 。 

区 a | 实例 20.6， 主 论坛 显示 

源码 路 径 : 光盘 \ 源 文件 20\20-6.php 


01 <?php 
02 echo "<html>"; 
03 echo "<head>"; 
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04 
05 
06 
07 
08 
09 
10 
11 
12 
13 
14 
15 
16 
17 
18 
19 
20 
21 
22 
23 
24 
25 
26 
27 
28 
29 
30 
31 
32 
33 
34 
35 
36 
37 
38 
39 
40 
41 
42 
43 
44 
45 
46 
47 
48 
49 
50 


echo "<title> 主 论坛 显示 </title>"; 

echo "</head>"; 

echo "<body>"; 

echo "<LINK href=\"style.css\" rel=stylesheet>"; 
echo "<center>"; 


if(l$_GET[id]) /如果 没有 参数 ， 显 示 内 容 


echo "<h2> 没 有 请 求 ID</h2>"; 
echo "<h3> 点 <a href-20-5.php»3X 8 «/a»jR [8] «/h3»"; 
exit(); 


// 如 果 存 在 参数 则 显示 相应 论坛 


require "20-1.php"; 

$sql-"select p id from $table topic where id-'$ GETR[id]"; 
S$resultzmysql! query($sql,$link) or die(mysql error()); 
$rows-mysql fetch array(S$result); 


if(Srows[0]I-0) /如 果 论 坛 不 是 主 论坛 
{ 

echo "<h2> 请 求 的 ID 不 是 主 论坛 </h2>"; /显示 信息 

echo "<h3> 点 <a href=20-5.php> 这 里 </a> 返 回 </h3>"; 

exit(); // 中 止 所 有 PHP 执行 
} 
else // 如 果 是 主 论坛 ， 显 示 HTML 
{ 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">"; 

echo "<tr>"; 

echo "<td>"; 

echo "<center><h2> 主 分 类 论坛 首页 </h2></center>"; 

echo "</td>"; 

echo "</tr>"; 

echo "</table>"; 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">"; 

echo "<tr>"; 

echo "<td><a href=20-5.php> 论 坛 首页 </a></td>"; 

echo "</tr>"; 

echo "</table>"; 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">"; 

echo "<tr>"; 


echo "<td> 论 坛 </td><td> 帖 数 </td><td> 主 题 </td><td> 最 后 帖 标题 </td><td> 最 后 帖 回复 时 间 </td>"; 
echo "</tr>"; 
$sql-"select * from $table topic where p id-'$ GET[id]"; 
S$resultemysql query($sql.Slink) or die(mysql error()); 
while($rows-mysql fetch array(Sresult)) /循环 显示 分 论坛 信息 
{ 
echo "<tr>"; 
echo "<td><a href=\"20-7.php?id=". $rows['id]."\">".$rows[topic_name']."</a><br>"; 
echo $rows[topic description')."</d>"; 
echo "«td»".$rows['post count]."«/td»"; 
echo "«td»".$rows['post m count']."«/td»"; 
$sql2-"select id,titlejpost re time from Stable posts where id-'$rows[last post id]"; 
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55 S$result22mysql query($sql2.Slink) or die(mysql error()); 

56 $rows2-mysq| fetch array(Sresult2); /显示 最 后 一 条 帖子 的 相关 信息 
57 echo "<td><a href=\"20-8.php?id=". $rows2['id']."\">". $rows2['title]."</a></td>"; 
58 echo "«td»".$rows2[post re time"."«/td»"; 

59 echo "</tr>"; 

60 } 

61 echo "</table>"; 

62 echo "</center>"; 

63 echo "</body>"; 

64 echo "</html>"; 

65 y 

66 } 

67 ?> 


单 击 图 20.8 中 的 “默认 主 类 别 1” 链 接 ， 将 执行 以 上 代码 并 且 带 有 参数 ID=1， 执 行 结果 如 图 20.9 
所 示 。 


lola ji) 
Qom E OA 
主 分 类 论坛 首页 
论坛 首页 
论坛 YA xs ”最 后 帖 标题 最 后 帖 四 复 对 间 
gl 1 1 EMA  — 2013 年 05 月 1612, 17, 27 
Xi» 7 


图 20.9 主 论坛 显示 执行 结果 


说 明 : 与 实例 20-5 不 同 的 是 ， 论 坛 首页 显示 文件 显示 所 有 主 分 类 论坛 及 其 下 面 的 分 论坛 的 信息 ， 而 主 
论坛 显示 页 则 只 显示 本 类 分 论坛 的 信息 。 


20.4.3 “分 论坛 显示 文件 的 创建 


GEH 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 20 章 \ 分 论坛 显示 文件 的 创建 .wmv 

本 小 节 来 创建 分 论坛 的 显示 页 面 文件 ， 该 文件 可 显示 当前 分 类 论坛 下 的 帖子 信息 ， 其 中 包括 标题 、 
作者 、 查 看 、 回 复 、 最 后 发 表 等 内 容 。 

【实例 20-7】 以 下 为 分 论坛 显示 文件 代码 。 


re 实例 20-7: 分 论坛 显示 
源码 路 径 : 光盘 \ 源 文件 20\20-7.php 


01 <?php 

02 echo "<html>"; 

03 echo "<head>"; 

04 echo "<title> 分 论坛 显示 </title>"; 
05 echo "</head>"; 

06 echo "<body>"; 
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echo "<LINK href=\"style.css\" rel=stylesheet>"; 
echo "<center>"; 


if(l$_GET[id]) // 如 果 没 有 参数 ， 显 示 内 容 


{ 


else 


ü 


echo "<h2> 没 有 请 求 ID</h2>"; 
echo "<h3> 点 <a href=20-5.php> 这 里 </a> 返 回 </h3>"; 
exit(); 


// 如 果 有 参数 提示 


require "20-1.php"; 

$sql-"select p id from $table topic where id-'$ GETR[id]"; 

S$result»mysql query($sql,Slink) or die(mysql error()); 
$rows-mysql fetch array(S$result); 

if($rows[0]--0) /如果 论坛 不 是 分 论坛 


echo "<h2> 请 求 的 ID 不 是 分 论坛 </h2>"; NETAS 
echo "<h3> 点 <a href-20-5.php»3X & «/a»jR [B] «/h3»"; 
exit(); 


else /请求 ID 是 分 论坛 ， 显 示 HTML 


echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">"; 
echo "<tr>"; 

echo "<td>"; 

echo "<center><h2> 分 论坛 首页 </h2></center>"; 

echo "</td>"; 

echo "</tr>"; 

echo "</table>"; 

$sql="select p id from Stable topic where id='$_GET[id]"; 
S$resultemysql query($sql,Slink) or die(mysql error()); 


$rows-mysq| fetch array(Sresult); // 获 取 主 论坛 ID 
echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">"; 
echo "<tr>"; 
echo "<td><a href=20-5.php> 论 坛 首 页 </a>|<a href=20-6.php?id=".$rows[0]."> 主 论坛 </a>"; 
echo "</td>"; // 显 示 论坛 首页 及 主 论坛 链接 
if$ COOKIE[user]) /| 判断 用 户 是 否 登录 
{ 
echo "<td align=right><a href=20-8.php?topic_ id=".$_GET[id]."> 发 表 新 主题 </a>"; 
echo "</td>"; /如果 用 户 已 经 登录 ， 显 示 发 帖 链接 
} 
echo "</tr>"; 
echo "</table>"; 
$sql="select id from $table posts where topic id-'$ GET[id] and re_id=0"; 
$result-mysql query ($sql.Slink); /获取 主 题 数 
$nums=mysql_num_rows($result); /获取 主题 总 数 
$p_count=ceil($nums/10); // 求 总 页 数 
if($ GET[page']--0 &&!$_GET[page]) // 如 果 没 有 请 求 页 面 
$page-1; // 当 前 页 为 第 一 页 
else 
$page=$_GET[page]; /获取 当前 页 
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$s=($page-1)*10+1; 


$s-$s-1; // 当 前 页 最 多 显示 数 
echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">"; 
echo "<tr>"; 


echo "<td> 标 题 </td><td> 作 者 </td><td> 查 看 </td><td> 回 复 </td><td> 最 后 发 表 </td>"; 
echo "</tr>"; 
$sql="select * from $table posts where topic id='$ GET[id] and re id=0 order by post 


re time desc limit $s, 10"; 
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81 
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84 
85 
86 
87 
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S$resultzmysql query($sql,Slink) or die(mysql error()); 
while($rowsemysql fetch array(Sresult)) IHE S zs T8 8 
í 
echo "<tr>"; 
echo "<td><a href-'20-8.php?id-".Srows[id'].""»".$rows['title']."«/a» «/td»"; 
echo "«td»" $rows['poster']."«/td»"; 
echo "«td»".$rows['view count')."</td>"; 
echo "<td>".$rows|'re count']."«/td»"; 
echo "«td2".$rows['post re time?."«/td»"; 


echo "</tr>"; 
H 
echo "</table>"; 
echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">"; 
echo "<tr>"; 
echo "<td>"; 
echo "<center>"; 
$prev_page=$page-1; /分 页 显示 前 一 页 
$next_page=$page+1; /定义 分 页 显示 下 一 页 
if ($page<=1) /如果 当前 页 小 于 等 于 1 
{ 
echo "第 一 页 |"; 
} 
else 1// 如 果 当 前 页 大 于 1 
{ 
echo "<a href='$PATH_INFO?page=1'> 第 一 页 </a> | "; 
} 
if ($prev_page<1) // 如 果 前 一 页 小 于 1 
{ 
echo "上 一 页 |"; 
} 
else // 如 果 前 一 页 大 于 等 于 1 
{ 
echo "<a href='$PATH_INFO?page=$prev_page'> 上 一 页 </a> | "; 
H 
if ($next page>$p count) /如果 下 一 页 大 于 总 页 数 
t 
echo "下 一 页 | "; 
} 
else // 如 果 下 一 页 小 于 等 于 总 页 数 
{ 
echo "<a href='$PATH_INFO?page=S$next_page'> 下 一 页 </a> |" 
} 
if ($page>=$p_count) /| 如 果 当 前 页 大 于 等 于 总 页 数 
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108 H 

109 echo "最 后 一 页 </p>"; 

110 } 

111 else // 和 如 果 当 前 页 小 于 总 页 数 
112 fi 

113 echo "<a href-'$PATH INFO?page-$p count'»&/ai — 9i «/a»«/p»"; 
114 

115 echo "</center>"; 

116 echo "</td>"; 

117 echo "«/tr»"; 

118 echo "</table>"; 

119 echo "</center>"; 

120 echo "</body>"; 

121 echo "</html>"; 

122 

123 

124 ?> 


单 击 图 20.9 中 的 “默认 分 类 别 ” 链 接 就 可 以 打开 分 论坛 显示 文件 并 且 带 有 参数 ID=2， 相 当 于 执行 
20-7.php?id=2， 执 行 结果 如 图 20.10 所 示 。 


[€] SIT P ~ Ó|&sesez | WA 
分 论坛 首页 
标题 fe 查看 。 HR RERE 
ESNEA admin 0 0 201351055168 12. 17. 27 
各 -页 | 上 一 页 | 下 一 页 | 最 后 一 页 
图 20.10 分 论坛 显示 页 面 执行 结果 
从 图 20.10 TURI, 显示 出 了 本 类 论坛 的 所 有 主题 ,并 且 显 示 了 主题 的 作者 、 查 看 次 数 、 回 复 次 
数 及 最 后 发 表 


论坛 的 显示 部 分 就 介绍 到 这 里 。20.5 节 将 开始 介绍 用 户 如何 发 表 新 主题 及 回复 已 经 存在 的 主题 。 


205 ”主题 的 显示 与 回复 


论坛 的 作用 就 是 用 户 之 间 可 以 就 某 一 主题 进行 讨论 ， 所 以 主题 的 显示 与 回复 是 论坛 所 有 实现 功能 
中 的 重 中 之 重 。 本 节 来 介绍 如 何 使 用 PHP 代码 实现 发 布 新 主题 ， 以 及 现 有 主题 的 显示 及 回复 功能 。 


20.5.0 发 表 新 主题 


GH 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 20 章 \ 主 题 的 显示 与 回复 .wmv 
发 表 新 主题 的 实现 方法 是 按照 用 户 的 输入 将 记录 添加 到 帖子 数据 表 。 


e. 
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【实例 20-8】 以 下 为 发 表 新 主题 代码 。 


01 
02 


«?php 


实例 20-8: 发 表 新 主题 
源码 路 径 : 光盘 \ 源 文件 20\20-8.php 


echo "<html>"; 

echo "<head>"; 

echo "<title> 发 表 新 主题 </title>"; 

echo "</head>"; 

echo "<body>"; 

echo "<LINK href=\"style.css\" rel=stylesheet>"; 
echo "<center>"; 


if 


COOKIE[user]) /用 户 没 有 登录 的 非法 请 求 


echo "<h2> 匿 名 用 户 不 允许 发 帖 ! </h2>"; 
echo "<h3> 点 <a href=20-4.php> 这 里 </a> 登 录 </h3>"; 
exit(); 


È 
if(I8 GETI topic id]) // 没 有 分 论坛 参数 


else 


{ 


echo "<h2> 没 有 请 求 ID</h2>"; 
echo "<h3> 点 <a href=20-5.php> 这 里 </a> 返 回 </h3>"; 
exit(); 


// 和 如果 有 请 求 分 论坛 ID 


require "20-1.php"; 

$sql-"select p id from $table topic where id-'$ GET[topic id]"; 
S$resultzmysql query(S$sql,Slink) or die(mysql error()); 
$rows-mysql fetch array(Sresult); 

if(Srows[0]--0) // 如 果 请 求 ID 不 是 分 论坛 


echo "<h2> 请 求 的 ID 不 是 分 论坛 </h2>"; 
echo "<h3> 点 <a href=20-5.php> 这 里 </a> 返 回 </h3>"; 
exit(); 
} 
else In i2 ie3z. 


if(IS POSTT[title']) // 如 果 没 有 提交 变量 则 显示 前 台 
t 
if(!8 GET[re id']) $re id-0; // 如 果 没 有 回复 ID 号 
else $re id-$ GET[re id]; /获取 回复 ID 号 
echo "<script language=\"javascript\">"; 
echo "function juge(theForm)"; 
echo "("; 
echo "if (theForm.title.value == \"\")"; 
echo "("; 
echo "alert(\" 请 输入 主题 名 称 ! \");"; 
echo "theForm.title.focus();"; 
echo "return (false);"; 
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47 echo "^ 

48 echo "if (theForm.content.value == \"\")"; 

49 echo "("; 

50 echo "alert(\" 请 输入 主题 内 容 ! \");"; 

51 echo "theForm.content.focus();"; 

52 echo "return (false);"; 

53 echo "^ 

54 echo "^; 

55 echo "</script>"; 

56 echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">"; 
57 echo "<tr>"; 

58 echo "<td>"; 

59 echo "<center><h2>"; 

60 if($re_id==0) echo "发 表 新 主题 "; 

61 else echo "发 表 回复 "; 

62 echo "</h2></center>"; 

63 echo "</td>"; 

64 echo "</tr>"; 

65 echo "</table>"; 

66 $sql-"select p id,topic name from $table topic where id-'$ GETf[topic id)"; 
67 $resultzmysql query($sql,Slink) or die(mysql error()); 

68 $rows-mysql fetch array(Sresult); 

69 echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">"; 
70 echo "<tr>"; 

71 echo "<td><a href=20-5.php> 论 坛 首页 </a>|<a href=20-6.php?id=".$rows[0]."> 主 论坛 
</a>|<a href=20-7.php?id=".$_GET[topic id].">".$rows[1]."</a></td>"; 

72 echo "</tr>"; 

73 echo "</table>"; 

74 echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">"; 
75 echo "<form method=\"post\ action=\"20-8.php?topic_id=".$_GETȚ['topic_id']."\" 
onsubmit=\"return juge(this)\">"; 

76 echo "<input type=hidden name=re_id value=".$re_id.">"; 

Tri echo "<tr>"; 

78 echo "<td> 输 入 标题 ，</td>"; 

79 echo "<td><input type=text name=title></td>"; 

80 echo "</tr>"; 

81 echo "<tr>"; 

82 echo "<td> 输 入 内 容 : </td>"; 

83 echo "<td><textarea rows=5 cols=50 name=content></textarea></td>"; 
84 echo "</tr>"; 

85 echo "<tr>"; 

86 echo "<td colspan=\"2\"><center><input type=submit value= 提 交 ><input type-reset 
value= 重 置 ></center></td>"; 

87 echo "</tr>"; 

88 echo "«form»": 

89 echo "</table>"; 

90 echo "</center>"; 

91 echo "</body>"; 

92 echo "</html>"; 

93 ) 

94 else /后 台 处 理 
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95 { 

96 $tite-$ POSTT title); /获取 参数 

97 $content=$_POST[content]; 

98 $re id-$ POST[Tre id]; 

99 $topic id-$ GETI topic id]; 

100 $ip-$ SERVERIREMOTE ADDRT; 

101 $time-date("'Y $£ m A d A G: i: s"); 

102 $sql="select id,nickname from $table members where name='$ COOKIE[user]"; 
103 $result-mysql query($sql,Slink); 

104 $rows-mysql fetch array(Sresult); 

105 $sql-"insert into Stable posts(topic id,re id,poster id,poster ip,poster;title,content, 
post time,post re time)values(Stopic id'/$re id''$rows[0]'/Sip'/$rows[nickname],,'Stitle''Scontent','Stime','$time")" 
106 if(mysql query(Ssql,Slink) or die(mysql error())) 

107 n 

108 if($re id--0) // 如 果 是 发 表 主题 的 操作 

109 ( 

110 $sql-"select max(id) from $table posts"; 

111 $resultzmysql query($sql,Slink); 

112 $rowszmysql fetch array(Sresult); 

113 echo $rows[0]; 

114 $sql-"update $table posts set re count-re count*1,post re time-'$time' 
where id-'$topic id"; 

115 mysql query($sql,Slink); 

116 j 

117 else // 如 果 是 发 表 回复 的 操作 

118 ( 

119 $sql-"update $table posts set re count-re count*1 where id-'Stopic id"; 
120 mysql query($sql,$link); 

121 ) 

122 S$sql-"update $table members set post num-post num*1 where id-'$rows[id]"; 
123 mysql query($sql,$link); 

124 S$sql-"update Stable topic set post count-post count*1 where id-'$tipic id"; 
125 mysql query($sql.$link); 

126 echo "添加 记录 成 功 ， 现 在 返回 分 论坛 页 "; 

127 echo "<meta http-equiv=\"refresh\" content=\"2; uri-20-7.php?id-".Stopic id.'V>"; 
128 } 

129 else 

130 { 

131 echo "添加 记录 时 出 错 ， 现 在 返回 "; 

132 echo "<meta http-equiv=\"refresh\" content=\"2; url-20-7.php?id-" Stopic id."V»"; 
133 } 

134 " 

135 } 

136 

137 ?> 


说 明 : 该 实例 中 最 为 关键 的 一 项 是 其 re id 字段 要 为 0。 这 样 就 代表 该 条 帖子 是 新 的 主题 了 。 
单 击 图 20.10 中 的 “发 表 新 主题 ”链接 就 可 以 执行 以 上 代码 ， 执 行 结果 如 图 20.11 所 示 。 


er] 
OG9s— some EST assez E. 
发 表 新 主题 
ETETEN 


图 20.11 发 表 新 主题 执行 结果 


按照 要 求 填 入 标题 及 内 容 ， 单 击 “ 提 交 ” 按 钮 就 可 以 发 表 新 主题 。 当 新 主题 成 功 发 布 后 ， 程 序 会 
自动 跳 转 到 相应 的 子 分 类 页 面 中 ， 如 图 20.12 所 示 。 


分 沦 去 首页 
2 而 | 主 论 二 pei 
标题 作者 查看 ng ë 最 后 发 表 
test Tom 0 1 2013 年 05 月 16 日 15，07，05 
kae. admin 0 0 201305516812: 17. 27 


第 -页 1 上 -页 1 下 -页 1 最 后 -页 


图 20.12 成功 发 布 新 主题 执行 结果 
这 样 新 主题 就 成 功 添加 到 帖子 的 表 中 了 。 
主题 成 功 入 库 还 是 不 够 的 , 必须 让 人 能 够 浏览 才 行 。20.5.2 小 节 就 来 介绍 如 何 显示 已 经 存在 的 主题 。 


20.5.2” 现 有 主题 的 显示 


YA 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 20 章 \ 现 有 主题 的 显示 .wmv 

本 小 节 来 讲解 如 何 显示 已 经 存在 的 主题 。 主 题 的 显示 也 很 简单 ， 首 先 获取 用 户 提交 的 ID， 然 后 判 
断 该 ID 所 对 应 的 帖子 是 否 是 主题 。 因 为 帖子 存在 主题 与 主题 的 回复 两 种 情况 ， 所 以 要 做 这 样 的 判断 。 
如 果 提交 的 ID 不 是 主题 ， 则 给 出 相应 提示 。 如 果 是 主题 ， 则 显示 该 主题 内 容 及 对 应 该 主题 的 回复 。 

【实例 20-9】 以 下 为 显示 现 有 主题 的 代码 。 


TE TI i209 graza AAA 
a-t 源码 路 径 : 光盘 \ 源 文件 20\20-9.php 


01 <?php 

02 echo "<html>"; 

03 echo "<head>"; 

04 echo "<title> 显 示 主 题 </title>"; 
05 echo "</head>"; 

06 echo "<body>"; 


07 
08 
09 
10 
11 
12 
13 
14 
15 
16 
17 
18 
19 
20 
21 
22 
23 
24 
25 
26 
27 
28 
29 
30 
31 
32 
33 
34 
35 
36 
37 
38 
39 
40 
41 
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echo "<LINK href=\"style.css\" rel=stylesheet>"; 
echo "<center>"; 


ifl$ GET[id]) // 如 果 没有 请 求 主题 ID 


echo "<h2> 没 有 请 求 ID</h2>"; 
echo "<h3> 点 <a href=20-5.php> 这 里 </a> 返 回 </h3>"; 
exit(); 


/ 旺 示 主题 内 容 


require "20-1.php"; 

$sql-"select * from $table posts where id-'$ GETTid]"; 

$result-mysql guery($sal,$link); 

$rows-mysql fetch array(Sresult); 

if(Srows[re id']I-0) // 如 果 请 求 ID 不 是 主题 


else 


echo "<h2> 请 求 的 帖子 不 是 主题 ! </h2>"; 
echo "<h3> 点 <a href=20-5.php> 这 里 </a> 返 回 </h3>"; 
exit(); 


echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">"; 

echo "<tr>"; 

echo "<td>"; 

echo "<center><h2> 主 题 显 示 </h2></center>"; 

echo "</td>"; 

echo "</tr>"; 

echo "</table>"; 

$sql2="select id,p id,topic name from $table topic where id-'$rowslitopic id)"; 
$result2-mysql query($sql2,Slink); 

$rows2-mysql fetch array($result2); 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">"; 

echo "<tr>"; 

echo "<td><a href=20-5.php> 论 坛 首页 </a>|<a href=20-6.php?id=".$rows2[1]."> 主 论坛 


</a>|<a href=20-7.php?id=".$rows2[0].">". $rows2[2]."</a>"; 
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echo "</td>"; 
echo "<td align=right><a href=20-8.php?topic_id=".$rows2[0]."> 发 表 新 主题 </a>|<a href= 


20-8.php?topic_id=".$rows2[0]."&re_id=".$_GET[id1."> 发 表 回复 </a>"; 


44 
45 
46 
47 
48 
49 
50 
51 
52 
53 
54 
55 


echo "</td>"; 

echo "</tr>"; 

echo "</table>"; 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">"; 
echo "<tr>"; 

echo "<td>"; 

echo "作者 : ".$rows['poster]; 

echo "<br> 作 者 ID: ".$rows[poster id; 
echo "<br> 作 者 IP: ".$rows['poster ip; 
echo "<br> 标 题 : ".$rows['itle]; 

echo "<br> 内 容 : ".$rows[content]; 

echo "<br> 发 表 时 间 : ".Srows[post time'; 
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echo "</td>"; 
echo "</tr>"; 
echo "<tr>"; 
echo "<td> 以 下 为 该 主题 的 回复 </td>"; 
echo "</tr>"; 
$sql="select * from $table posts where re id-'$ GETI[id]"; 
S$result-mysql query($sql.Slink); 
while($rowszmysql fetch array($result)) 
t 
echo "<tr>"; 
echo "<td>"; 
echo "Es: ".$rows[poster]; 
echo "<br> 作 者 ID: ".$rows[' poster. id']; 
echo "<br> 作 者 IP: ".Srows[poster ip']; 
echo "<br> 标 题 : ".$rows[title]; 
echo "<br> 内 容 : ".$rows['content']; 
echo "<br> 发 表 时 间 : ".Srows[post time']; 
echo "</td>"; 
echo "</tr>"; 


H 

$sql-"update $table posts set view count-view count*1 where Sid-'$ GET[id]"; 
mysql query($sql,Slink); 

echo "</table>"; 

echo "</center>"; 

echo "</body>"; 

echo "«/html»"; 


注意 : 这 里 涉及 对 多 个 表 的 查询 与 读 取 。 既 要 读 取 帖 子 相关 内 容 ， 也 要 读 取 帖 子 对 应 的 分 类 数据 表 记 


录 。 另 外 ， 在 浏览 主题 的 同时 要 记得 每 请 求 一 次 主题 显示 文件 ， 就 要 给 主题 的 浏览 次 数 即 
View_count 增 加 1， 这 样 才能 准确 地 获得 主题 的 浏览 次 数 。 


单 击 图 20.12 中 帖子 标题 的 链接 就 可 以 进入 相应 的 主题 显示 页 面 。 如 单 击 “ 第 一 条 测试 信息 ”链接 ， 


执行 结果 如 图 20.13 所 示 。 


m Toe 
OO arrena 2-O[es FO 
主题 显示 

论坛 首页 | 主 论坛 | 默认 分 灶 别 发 去 新 主题 | 发 去 回复 

作者 ， admin 

作者 ID: 1 

作者 IP，127.0.0.1 

标题 : 第 一 条 测试 信息 


内 容 测试 发 帖 是 否 有 效 
发 表 时 间 ，2013 年 05 月 16 日 12，17， 27 
以 下 为 六 主题 的 回复 


Rao - 


图 20.13 主题 显示 执行 结果 
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从 图 20.13 可 以 发 现 , 程序 正确 地 显示 出 了 相应 主题 及 发 帖 者 的 相关 信息 。 下 面 来 介绍 如 何 对 主题 
进行 回复 。 


20.5.3 ”主题 的 回复 


GR 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 20 章 \ 主 题 的 回复 .wmv 

对 主题 进行 回复 ， 只 需要 给 20-8.php 加 上 相应 的 参数 即 可 实现 。 在 编写 20-8.php 时 曾 用 到 这 样 的 
参数 re_id， 当 该 参数 为 0 时 ， 表 示 是 发 表 新 的 主题 ， 而 当 该 值 为 其 他 数值 时 说 明 是 对 ID 号 为 该 值 的 
主题 进行 回复 。 在 这 里 直接 调用 即 可 实现 对 主题 的 回复 。 

不 过 回复 的 操作 并 不 只 是 把 用 户 输入 记录 添加 进 表 就 行 了 ， 还 要 进行 一 系列 的 操作 。 如 使 分 类 表 
中 相应 记录 的 帖子 数 自 增 1、 相 应 用 户 的 发 帖 数 自 增 1、 相 应 主题 的 回复 数 自 增 1 等 。 

单 击 图 20.13 中 的 “发 表 回 复 ” 链 接 ， 将 打开 20-8.php。 不 过 不 同 的 是 ， 已 经 不 是 发 表 新 主题 ， 而 
是 回复 主题 了 。 填 写 相 应 的 标题 及 内 容 。 提 交 回 复 后 ， 将 回 到 分 论坛 页 ， 单 击 回复 的 主题 以 查看 回复 
是 否 正 确 显示 ， 执 行 结果 如 图 20.14 所 示 。 


[ENS 
[c] [e ve j/localhost/20-3.pho'd-t. P~ Ó| Sz x| AEH 


EX SE 
论坛 首页 | 主 论坛 | 默认 分 类 别 发 表 新 主题 | 发 表 回复 


标题 ， 间 一 箱 测试 信息 

内 容 ， 测 试 发 帖 是 否 有 效 

发 表 时 间 ，2013 年 05 月 16 日 12，17:， 27 
以 下 为 谅 主题 的 回复 

作者 ，Tom 

作者 ID，1 

fFÉIP. 127.0.0.1 

ME RAT 

AR: (RES REI 

发 表 时 间 ，2013 年 05 月 16 日 15，20，52 


图 20.14 回复 过 的 主题 显示 页 执行 结果 


显示 回复 时 , 只 需要 把 回复 内 容 跟 在 主题 后 面 即 可 。 从 图 20.14 可 以 看 出 正确 地 显示 了 已 经 存在 的 
主题 内 容 及 相应 的 回复 。 

关于 主题 帖子 的 显示 与 回复 本 节 就 介绍 到 这 里 ， 接 下 来 的 几 节 来 重点 介绍 管理 员 或 者 版 主 才 有 的 
权限 的 内 容 ， 如 对 整个 论坛 分 类 的 管理 、 对 帖子 的 管理 等 内 容 。 


20.6 ”论坛 分 类 的 管理 
系统 在 进行 安装 时 创建 了 默认 的 主 类 别 及 分 类 别 ， 但 这 对 于 一 个 通用 的 论坛 来 说 是 远 远 不 够 的 。 


应 该 给 予 管理 员 相应 的 权限 ， 以 创建 新 的 类 别 。 本 节 就 来 讲 讲 如 何 对 论坛 的 分 类 进行 管理 ， 其 中 包括 
为 论坛 增加 新 的 类 别 ， 及 更 改 现 有 的 类 别 。 通 常情 况 下 ， 一 个 论坛 分 类 在 创建 后 就 不 能 被 删除 了 ， 所 


NK! 
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以 就 不 再 讨论 如 何 删除 分 类 的 问题 。 
20.6.1 为 论坛 增加 新 的 类 别 


GB 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 20 章 \ 为 论坛 增加 新 的 类 别 .wmv 

为 论坛 增加 类 别 包括 两 种 情况 ， 一 种 是 增加 主 分 类 即 主 论坛 ， 另 一 种 是 为 某 一 存在 的 主 分 类 增加 
二 级 分 类 即 分 论坛 。 在 有 些 比较 大 型 的 论坛 程序 中 ， 甚 至 还 有 三 级 或 者 多 级 的 分 类 。 这 里 只 探讨 二 级 
的 情况 。 

为 论坛 增加 新 的 类 别 的 操作 分 儿 步 进行 。 第 一 步 ， 先 让 用 户 选择 欲 创建 的 类 别 是 主 类 别 还 是 分 类 
别 。 第 二 步 ， 如 果 用 户 选择 的 是 主 类 别 ， 在 这 一 步 直接 输入 类 别名 称 及 介绍 等 相应 信息 即 可 ; 如果 用 
户 在 上 一 步 选择 的 是 分 类 别 ， 则 还 需要 让 用 户 选 择 ， 该 分 类 别 属于 已 经 存在 的 哪 一 个 主 类 别 。 然 后 再 
按照 选择 输入 类 别名 称 、 类 别 说 明 等 内 容 。 

【实例 20-10】 以 下 为 为 论坛 增加 新 类 别 代码 。 

区 a | 实例 20-10: 为 论坛 增加 新 类 别 

B. 源码 路 径 ， 光盘 \ 源 文件 20\20-10.php 


01 <?php 

02 echo "<html>"; 

03 echo "<head>"; 

04 echo "<title> 增 加 新 论坛 </title>"; 

05 echo "</head>"; 

06 echo "<body>"; 

07 echo "<LINK href=\"style.css\" rel-stylesheet?"; 

08 echo "<center>"; 

09 require "20-1.php"; 

10 $sql="select admin from $table members where name-'$ COOKIE([user]"; 
11 $resultzmysql query($sql,Slink); 

12 $rowszmysq| fetch array(Sresult); 

13 if($rows['admin]«3) 

14 { 

15 echo "<h2> 你 没有 这 项 权限 来 运行 该 文件 ! </h2>"; 

16 echo "<h3> 点 <a href=20-5.php> 这 里 </a> 返 回 </h3>"; 

17 exit(); 

18 } 

19 else 

20 

21 if(!$_POSTT'topic") 

22 ( 

23 echo "<table width=\"80%\" cellpadding-V 1 cellspacing=\"1\">"; 
24 echo "<form method=\"post\" action=\"".$_SERVER['PHP_SELF']."\">"; 
25 echo "<tr>"; 

26 echo "<td colspan=\"2\"><center><h2> 创 建 论坛 分 类 第 一 步 </h2></center></td>"; 
27 echo "</tr>"; 

28 echo "<tr>"; 

29 echo "<td> 选 择 创建 类 别 </td>"; 

30 echo "<td>"; 
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31 echo "<select size=\"1\" name=\"topic\">"; 

32 echo "<option value=\"1\"> 主 类 别 </option>"; 

33 echo "<option value=\"2\"> 分 类 别 </option>"; 

34 echo "</select>"; 

35 echo "</td>"; 

36 echo "</tr>"; 

37 echo "<tr>"; 

38 echo "<td colspan=\"2\"><center><input type=submit value=\" 下 一 步 \"></td>"; 
39 echo "«/tr»"; 

40 echo "</form>"; 

41 echo "</table>"; 

42 echo "</center>"; 

43 echo "</body>"; 

44 echo "</html>"; 

45 ) 

46 else if(!$ POST[topic name") 

47 { 

48 echo "<script language-'javascriptV 2"; 

49 echo "function juge(theForm)"; 

50 echo "f"; 

51 echo "if (theForm.topic name.value == \"\")"; 

52 echo "f"; 

53 echo "alert(\" 请 输入 类 别名 称 ! V)": 

54 echo "theForm.topic name.focus();"; 

55 echo "return (false);"; 

56 echo "}"; 

57 echo "if (theForm.topic description.value == \"\")"; 

58 echo "f"; 

59 echo "alert(\" 请 输入 类 别 介绍 ! Vy" 

60 echo "theForm.topic description.focus();"; 

61 echo "return (false);"; 

62 echo "}"; 

63 echo ")"; 

64 echo "</script>"; 

65 echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">"; 
66 echo "<form method=\"post\" action=\"".$_SERVER['PHP_SELF']."\" onsubmit-V'return 
juge(this)\">"; 

67 echo "<tr>"; 

68 echo "<td colspan=\"2\"><center><h2> 创 建 论坛 分 类 第 二 步 </h2></center></td>"; 
69 echo "</tr>"; 

70 echo "<input type=\"hidden\" name=\"topic\" value=\"".$_POST['topic]."\">"; 
71 if$ POST[topic]--2) 

72 { 

73 echo "<tr>"; 

74 echo "<td> 选 择 分 类 别 所 属 主 类 </td>"; 

75 echo "<td>"; 

76 echo "<select size=\"1\" name=\"p_id\">"; 

T $sql-"select id,topic name from $table topic where p id-0"; 
78 $result-mysql! query($sql.Slink); 

79 while($rowszmysql fetch array($result)) 

80 i 
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81 echo "<option valuez1".Srows['id].""".$rows['topic name"]."«/option"; 
82 n 

83 echo "</select>"; 

84 echo "</td>"; 

85 echo "</tr>"; 

86 ) 

87 echo "<tr>"; 

88 echo "<td> 输 入 类 别名 称 </td>"; 

89 echo "«td»"; 

90 echo "<input type=\"text\" name=\"topic_name\">"; 

91 echo "</td>"; 

92 echo "</tr>"; 

93 echo "<tr>"; 

94 echo "<td> 输 入 类 别 介绍 </td>"; 

95 echo "«td»"; 

96 echo "<input type=\"text\" name-'topic description» "; 
97 echo "</td>"; 

98 echo "</tr>"; 

99 echo "<tr>"; 

100 echo "<td colspan- V2» «center» «input type=button value=\" 上 一 步 \" onclick=\"history.go 
(-1) '»«input type=submit value=\" 下 一 步 \*></td>"; 

101 echo "</tr>"; 

102 echo "</form>"; 

103 echo "</table>"; 

104 echo "</center>"; 

105 echo "</body>"; 

106 echo "«/html»"; 

107 ) 

108 else 

109 { 

110 $topic=$_POST[Ttopic]; 

111 $topic name-$ POST[topic nameT; 

112 $topic description-$ POST[topic description]; 

113 if($topic==2) 

114 { 

115 $p_id=$_POST[p_id]; 

116 } 

117 $sql="insert into Stable topic(p_id,topic_name,topic_description)values('$p_id','$topic_ 
name','$topic description')"; 

118 if(mysql_query($sql,$link)) 

119 { 

120 echo "增加 新 论坛 操作 成 功 ， 现 在 返回 首页 ! "S 

121 echo "<meta http-equiv=\"refresh\" content=\"2; url=20-5\">"; 
122 } 

123 else 

124 { 

125 echo "增加 新 论坛 操作 失败 ， 现 在 返回 ! "; 

126 echo "<meta http-equiv=\"refresh\" content=\"2; url=20-10\">"; 
127 } 

128 ) 

129 ) 


e. 


130 ?> 


注意 : 为 论坛 增加 新 类 别 是 管理 员 才 具有 的 权限 。 
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直接 在 PHP 运行 环境 下 执行 实例 。 如 果 没 有 相应 的 权限 ， 则 会 出 现 如 图 20.15 所 示 的 提示 。 
而 如 果 已 经 以 管理 员 身份 进行 登录 ， 重 新 执行 该 PHP 文件， 执行 结果 如 图 20.16 所 示 。 


[EIE 
E Hip//llocahosuzt D ~ 出 Sers 


(9 


你 没有 这 项 权限 来 运行 该 文件 ! 
点 这 里 返回 


R10% ~ 


图 20.15 无 权限 时 执行 增加 新 类 别 文件 执行 结果 


Fc" 


创建 论坛 分 类 第 一 步 
ARARA [EAV] 
T-E 


J| & rtp;/localhosus O ~ © 


图 20.16 以 管理 员 身份 执行 添加 操作 第 一 步 


这 一 步 很 简单 ， 只 需要 选择 相应 的 类 别 即 可 。 这 里 选择 创建 分 类 别 ， 然 后 单 击 “ 下 一 步 ” 按 钮 则 


会 出 现 如 图 20.17 所 示 的 画面 。 


tei 


[e mim] 


(C3 [E resutociessx 2 ~ © EE 


: 


创建 论坛 分 类 第 二 步 
AES ASSURER RS 


箱 入 类 别名 称 
输入 类 别 介绍 


EJF 


—5 
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20.17 ”以 管理 员 身 份 执行 添加 操作 第 二 步 


由 于 要 创建 的 是 分 类 别 ， 所 以 要 选择 分 类 别 所 属 
类 别 ， 所 以 不 用 选择 也 可 以 。 然 后 输入 类 别 相应 名 称 
功 执行 的 话 ， 程 序 会 在 执行 完 相应 的 操作 后 直接 跳 转 
否 添加 成 功 。 执 行 结果 如 图 20.18 所 示 。 


的 主 类 别 。 但 目前 论坛 分 类 数据 表 中 只 有 一 个 主 
及 简单 介绍 即 可 。 单 击 “ 下 一 步 ” 按 钮 ， 如 果 成 
到 论坛 的 首页 。 也 可 以 通过 首页 的 显示 ， 查 看 是 


人 : [8 hes ocahest2 spro 


论坛 首页 
E3RP. admin 
论坛 名 称 。 ”论坛 介绍 
默认 主 类 别 1。 系统 创建 的 默认 主 类 别 
Door ME T EE 
通 加 的 条 类 别 测试 用 的 类 别 


帖子 数量 主题 数量 


1 
0 


1 
0 


P~ Ó|ssssz 


最 后 帖子 标题 。 景 后 帖子 回复 时 间 


至 一 科 测试 信忠 201305516812. 17. 27 


Mu 7 


图 20.18 ”成功 添加 相应 类 别 后 的 首页 


KA PHPBIBSURH CREER 


比较 图 20.18 与 图 20.8 可 以 发 现 ， 除 第 一 个 分 类 别 的 帖子 数量 上 有 区 别 之 外 还 有 一 个 区 别 就 是 多 
出 了 一 个 新 的 分 类 别 ， 这 就 说 明 添 加 操作 成 功 执行 。 

有 一 点 要 引起 注意 ， 由 于 用 户 发 帖 都 是 基于 分 类 别 发 帖 的 ， 所 以 如 果 一 个 主 类 别 下 边 没 有 相应 的 
它 是 不 会 被 显示 的 。 所 以 ， 在 添加 完 一 个 主 类 别 后 必须 为 其 添加 相应 的 分 类 别 。 


分 类 别 ， 


20.6.2 ”更 改 现 有 类 别 


多 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 20 章 \ 更 改 现 有 类 别 .wmv 
论坛 的 分 类 在 创建 后 不 能 一 成 不 变 ， 最 起 码 在 创建 初期 应 该 会 有 改变 。 如 系统 默认 的 类 别 并 不 符 
合用 户 使 用 的 要 求 ， 所 以 就 要 改变 相应 类 别 的 名 称 或 者 类 别 简介 等 内 容 。 本 小 节 就 来 介绍 对 现 有 类 别 
的 修改 操作 。 
注意 : 由 于 某 一 类 别 的 主题 数 及 帖子 数 等 属性 是 动态 生成 的 ， 并 与 论坛 的 帖子 数据 表 是 紧密 相连 的 ， 
所 以 不 能 修改 这 些 内 容 ， 只 能 修改 类 别名 称 、 类 别 简介 及 分 类 别 所 属 主 类 别 这 些 内 容 。 


【实例 20-11】 以 下 为 更 改 现 有 类 别 的 代码 。 


01 


«?php 


实例 20-11: 更 改 现 有 类 别 
源码 路 径 ， 光盘 \ 源 文件 20\20-11.php 


echo "<html>"; 

echo "<head>"; 

echo "<title> 修 改 已 有 的 论坛 </title>"; 

echo "</head>"; 

echo "<body>"; 

echo "<LINK href=\"style.css\" rel=stylesheet>"; 
echo "<center>"; 

require "20-1.php"; 

$sql-"select admin from $table members where name-'$ COOKIE[user]"; 
$result«mysql query ($sql, link); 
$rows-mysql fetch array(Sresult); 
if(Srows['admin']«3) 


echo "<h2> 你 没有 这 项 权限 来 运行 该 文件 ! </h2>"; 
echo "<h3> 点 <a href=20-5.php> 这 里 </a> 返 回 </h3>"; 


exit(); 

) 

else 
if(I8 POST[id']) 
t 


echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">"; 

echo "<form method=\"post\" action=\"".$_SERVER[PHP_SELF]."\">"; 
echo "<tr>"; 

echo "<td colspan=\"4\"><center><h2> 修 改 论坛 第 一 步 </h2></center></td>"; 
echo "</tr>"; 

echo "<tr>"; 
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48 
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50 
51 
52 
53 
54 
55 
56 
57 
58 
59 
60 
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) 
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echo "<td> 选 择 论坛 </td>"; 
echo "<td> 主 /分 </td>"; 
echo "<td> 论 坛 名 称 </td>"; 
echo "<td> 论 坛 简介 </td>"; 
echo "</tr>"; 
$sql="select id,p id,topic name,topic description from $table topic"; 
S$result-mysql query($sql,Slink); 
while($rows-mysql fetch array(Sresult)) 
1 
echo "<tr>"; 
echo "<td><input type- "radio" name=\"id\" value=\"".$rowsf'id']."\"></td>"; 
echo "<td>"; 
if($rows[p_id]==0) 
{ 
echo " 主 论坛 "; 


echo "分 论坛 "; 
H 
echo "</td>"; 
echo "<td>".$rows| topic name']."«/td»"; 
echo "<td>".$rows| topic description]."«/td»"; 
echo "</tr>"; 
) 
echo "<tr>"; 
echo "<td colspan-l"4V'» «center» «input type=submit value=\" 下 一 步 \"></td>"; 
echo "</tr>"; 
echo "</form>"; 
echo "</table>"; 
echo "</center>"; 
echo "</body>"; 
echo "«/html»"; 


else if(8 POST[topic name") 


{ 


echo "<script language=\"javascript\">"; 
echo "function juge(theForm)"; 

echo "f"; 

echo "if (theForm.topic name.value == \"\")"; 
echo "f"; 

echo "alert(\" 请 输入 类 别名 称 ! Vy" 

echo "theForm.topic name.focus();"; 

echo "return (false);"; 

echo "}'; 

echo "if (theForm.topic description.value == \"\")"; 
echo "f"; 

echo "alert(\" 请 输入 类 别 介绍 ! \");"; 

echo "theForm.topic description.focus();"; 
echo "return (false);"; 

echo ^; 
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80 echo ^: 

81 echo "</script>"; 

82 echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">"; 

83 echo "<form method=\"post\" action=\"".$ SERVER[PHP SELF]."" onsubmit=\"retum 
juge(this)\">"; 

84 echo "<tr>"; 

85 echo "<td colspan=\"2\"><center><h2> 创 建 论坛 分 类 第 二 步 </h2></center></td>"; 
86 echo "</tr>"; 

87 echo "<input type=\"hidden\" name=\"id\" value=\".$_ POSTT['id']."»"; 
88 $sql-"select * from $table topic where id-'$ POST[id]"; 

89 S$result-mysql query($sql.Slink); 

90 $rows-mysql fetch array(Sresult); 

91 if($rows[p. id']-0) 

92 ( 

93 echo "<tr>"; 

94 echo "<td> 选 择 分 类 别 所 属 主 类 </td>"; 

95 echo "<td>"; 

96 echo "<select size=\"1\" name=\"p_id\">"; 

97 $sql2-"select id,topic name from $table topic where p id-0"; 
98 S$result22mysql query($sql2,Slink); 

99 while($rows2-mysql fetch array($result2)) 

100 { 

101 echo "<option value=\"". $rows2["id"]; 

102 if($rows2[id']--$rows[p id']) echo " checked "; 

103 echo ""»".$rows2['topic name7."«/option"; 

104 ) 

105 echo "</select>"; 

106 echo "«/td»"; 

107 echo "</tr>"; 

108 ) 

109 echo "<tr>"; 

110 echo "<td> 输 入 类 别名 称 </td>"; 

111 echo "<td>"; 

112 echo "<input type=\"text\" name=\"topic_name\" value=\"".$rows['topic_name']."\">"; 
113 echo "«/td»"; 

114 echo "</tr>"; 

115 echo "<tr>"; 

116 echo "<td> 输 入 类 别 介绍 </td>"; 

117 echo "<td>"; 

118 echo "<input type=\"text\" name=\"topic_description\" value=\"". $rows[topic_description].\">"; 
119 echo "</td>"; 

120 echo "</tr>"; 

121 echo "<tr>"; 

122 echo "<td colspan=\"2\"><center><input type=button value=\" 上 一 步 \* onclick=\"history. 
go(-1)\"><input type=submit value=\" 下 一 步 \*></td>"; 

123 echo "</tr>"; 

124 echo "</form>"; 

125 echo "</table>"; 

126 echo "</center>"; 

127 echo "</body>"; 

128 echo "</html>"; 


e. 
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$id=$_ POST[id]; 

$topic-$ POSTT[topic]; 

$topic name-$ POST[topic name'; 

$topic description-$ POST[topic description']; 
if(S POST[p id]) 


$p id-$ POST[p id'; 
) 
else 

$p id-0; 


$sql-"update $table topic set p id-'$p id'topic name-'$topic name',topic description- 


'$topic description' where id-$id"; 


145 
146 
147 
148 


if(mysql query($sql,Slink)) 


echo "修改 论坛 操作 成 功 ， 现 在 返回 首页 ! "S 
echo "<meta http-equiv=\"refresh\" content=\"2; url=20-5.php\">"; 


} 
else 

echo "修改 论坛 操作 失败 ， 现 在 返回 ! "S 

echo "<meta http-equiv=\"refresh\" content=\"2; url=20-10.php\">"; 
} 


注意 : 与 增加 新 类 别 操作 一 样 ， 如 果 没 有 相应 的 权限 ， 执 行 该 文件 将 出 现 与 图 20.15 一 样 的 提示 。 
如 果 以 管理 员 身 份 运行 该 文件 ， 执 行 结果 如 图 20.19 所 示 。 


[一 
o Fm [TTE B pg 已 SI 


修改 论坛 第 一 步 
uu 主 /分 论坛 名 称 论坛 简介 
主 论坛 默认 主 关 别 1 。 系统 创建 的 默认 主 夫 四 4 
分 论坛 s Ric ES 
分 论坛 SEM 


L Tos - 


图 20.19 ”以 管理 员 身份 执行 修改 操作 第 一 步 


这 里 显示 出 了 目前 论坛 中 的 所 有 一 级 论坛 及 二 级 论坛 。 选 中 前 面 的 单 选 按钮 以 选择 相应 的 记录 进 
行 操作 。 这 里 选择 对 默认 分 类 别 进行 修改 操作 。 选 择 好 后 ， 单 击 “ 下 一 步 ”按钮 将 出 现 如 图 20.20 所 示 


的 执行 结果 。 
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创建 论坛 分 类 第 二 步 


涛 择 分 类 别 所 属 主 夫 EELE] 

输入 类 别名 称 EBVEII 

输入 类 别 介 招 AEREE] 
ES [TÉ 


Rios - 


图 20.20 ”以 管理 员 身 份 执行 修改 操作 第 二 步 


从 图 20.20 可 以 看 出 ,这 里 能 够 对 分 类 别 的 所 属 主 类 别 (如果 操 作 的 是 主 类 别 将 没有 这 一 项 ) 、 类 
别名 称 、 类 别 介绍 等 内 容 进行 修改 。 这 里 把 类 别名 称 更 改 为 “PHP 编程 ”， 类 别 介 绍 修改 为 “PHP 编 
程 专区 ， 欢 迎 各 位 PHP 菜鸟 大 虾 光临 ! ”。 由 于 现在 只 有 一 个 主 类 别 ， 所 以 主 类 别 必 须 选择 “默认 主 
类 别 1”。 然 后 单 击 “ 下 一 步 ”按钮 ， 如 果 操 作成 功 ， 程 序 将 自动 跳 转 到 论坛 首页 ， 如 图 20.21 所 示 。 


Vei n 
Qs »- Ojee x] MCA 
^l 
论坛 首页 
登录 用 户 : admin 
论坛 名 称 dünne ETR DER RENTE 最 后 帖子 回复 时 间 
Bild. 系统 创建 的 黑 认 主 类 别 
o  PHPÁRESU, XJUDERSPHPSS) ESME 2013505H16B12. 
PAESE Rei t E EE 17, 27 
Bem 测试 用 的 类 别 0 0 
~ 
LINE 


图 20.21 成 功 修改 相应 类 别 后 的 首页 


从 图 20.21 可 以 看 出 相应 的 类 别 已 经 被 修改 了 。 同 理 , 也 可 以 对 主 类 别 或 者 其 他 所 有 类 别 进行 相应 
修改 。 下 面 把 “默认 主 类 别 1” 修 改 为 “网 络 编程 区 ”， 把 类 别 介绍 修改 为 “网 络 语言 编程 区 : 有 PHP. 


ASP, JavaScript 等 内 容 ”， 修 改 后 的 结果 如 图 20.22 所 示 。 


l= = mend 
人 1) [B ies Mecabestzo sohe ERI EP a e 

论坛 首页 
BRAA. admin 
waak 论坛 介绍 Wm ism REETA pentane 
网 给 绾 程 区 ， 网 络 语言 编 程 区 ， 有 PHP、ASP、]avaScript 等 六 容 

PHP 骗 律 专区 ， 欢 迎 各 位 PHP 荣 鸟 BWA 2013505816812. 
PHPER aedi à 1 2a 17: 27 
Baas mammas o o 
R00% 


图 20.22 主 类 别 修改 之 后 的 首页 显示 效果 
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因为 通常 情况 下 不 需要 对 论坛 分 类 进行 删除 操作 ， 所 以 这 里 要 介绍 的 论坛 分 类 就 不 再 探讨 分 类 的 
删除 问题 。 

至 此 ， 论 坛 分 类 管理 就 为 读者 介绍 完毕 。 从 这 两 节 的 介绍 可 以 看 出 ， 对 论坛 分 类 的 管理 ， 实 际 上 
还 是 对 数据 表 的 添加 或 者 修改 操作 。 只 要 明白 其 中 的 道理 ， 一 切 都 变 得 很 简单 。 


20.7 ”帖子 的 管理 


本 节 来 介绍 对 论坛 中 帖子 的 管理 。 帖 子 是 构成 论坛 的 灵魂 ， 论 坛 只 有 有 了 好 帖子 才能 发 挥 其 生命 
力 。 同 理 ， 那 些 广告 帖 、 垃 圾 帖 、 含 有 不 合法 内 容 的 帖子 则 应 及 时 清除 。 本 节 主 要 讲 如 何 对 帖子 进行 
管理 ， 其 中 包括 帖子 的 编辑 、 非 法 帖 的 删除 、 如 何 防止 用 户 恶 意气 墓 等 内 容 。 


20.7.1 编辑 帖子 


E 知识 点 讲解 : 光盘 \ 视 频 讲 解 \ 第 20 章 \ 编 辑 帖子 -wmv 

用 户 发 的 帖子 中 ， 有 时 会 有 一 些 不 恰当 的 内 容 ， 或 者 用 户 发 错 的 内 容 。 这 就 应 该 给 管理 员 和 帖子 
的 作者 有 编辑 帖子 内 容 的 权限 。 这 里 要 对 显示 帖子 的 页 面 〈 实 例 20-9) 做 一 定 改动 ， 给 相应 的 帖子 上 
显示 出 “编辑 ”链接 。 当 用 户 有 编辑 权限 时 〈 这 里 有 两 种 情况 ， 一 种 是 用 户 本 身 是 论坛 管理 员 或 者 相 
应 区 的 版 主 ， 另 一 种 是 这 条 帖子 的 作者 就 是 浏览 的 用 户 本 人 〉 ， 显 示 该 链接 。 反 之 不 显示 。 这 样 ， 就 
可 以 实现 帖子 的 编辑 了 。 

具体 怎么 改动 呢 ? 下面 给 出 具体 的 代码 。 

分 别 找到 显示 主题 与 回复 代码 中 的 这 样 的 内 容 : 

echo "«td»"; 

echo "标题 : ".$rows[title]; 

echo "</td>"; 

把 上 面 的 内 容 改 为 : 

echo "«td»"; 

echo "标题 : ".$rowstitle]; 

if($rows tl'admin']-73) or ($rows[0]==$_COOKIE[user])) 1/ 判断 用 户 与 帖子 作者 是 否 是 同一 人 

echo" «a href=\"20-12.php?id=".$rows[id]."\"> 编 辑 </a>"; 

echo "</td>"; 


这 样 当 浏 览 的 用 户 与 发 帖 ( 或 者 回复 ) 的 作者 是 同一 个 人 的 话 ， 就 会 在 帖子 或 者 回复 的 标题 后 显 
示 出 “编辑 ”链接 ， 以 方便 用 户 对 帖子 实现 编辑 操作 。 
也 可 以 这 样 : 


echo "<td>"; 

echo "标题 : "Srows[title]; 

$sql_t="select admin from $table members where name-'$ COOKIE[user]"; 
$result t2mysql query($sql t.Slink); 

$rows t-mysql fetch array($result t); 

if(Srows t[admin]-73) 


71 


T 
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echo" <a hrefzV'20-12.php?idz" $rows[id].""» 4&$8 «/a»"; 
echo "</td>"; 


说 明 : 上 面 的 修改 是 让 管理 员 也 有 编辑 帖子 的 权限 。 与 普通 用 户 不 同 ， 普 通用 户 只 能 修改 自己 所 发 的 


帖子 ， 而 管理 员 则 可 以 修改 所 有 的 帖子 。 
经 过 以 上 修改 ， 再 次 运行 实例 20-9 时 的 结果 如 图 20.23 所 示 。 


Qe ee 


| RAN ECZ Pi 发 去 新 王 题 | 发 去 回复 
ien admin 


| TRIP, 127.0.0.1 
pe Emo ise E 
性 试 友 帖 是 否 有 效 
ERI. 201305168 12, 17. 27 
以 下 为 该 主题 的 四 复 


BID. 201350581615. 20. 52 


图 20.23 ”加 入 “编辑 ”链接 的 主题 显示 页 面 
经 过 以 上 的 修改 ， 对 帖子 进行 修改 的 准备 工作 就 算 做 完了 。 
【实例 20-12】 以 下 为 修改 帖子 内 容 的 代码 。 


7] ”实例 20-12: 修改 帖子 内 容 
源码 路 径 ， 光盘 \ 源 文件 20\20-12.php 


<?php 
echo "<html>"; 
echo "<head>"; 
echo "<title> 编 辑 帖 子 </title>"; 
echo "</head>"; 
echo "<body>"; 
echo "<LINK href=\"style.css\" rel=stylesheet>"; 
echo "<center>"; 
if(!$_GETT'id") 
{ 


echo "<h2> 没 有 请 求 ID</h2>"; 
echo "<h3> 点 <a href=20-5.php> 这 里 </a> 返 回 </h3>"; 
exit(); 


else 


{ 
require "20-1.php"; 


01 
02 
03 
04 
05 
06 
07 
08 
09 
10 
11 
12 
13 
14 
15 
16 
17 
18 
e. 


S$sql-"select poster,topic id,re id;title,content from Stable posts where id-'$ GET[id]"; 


#20% 简单 的 BBS 系统 ES 


19 S$result-mysql query(S$sql.Slink) or die(mysql error()); 

20 $rows-mysql fetch array(S$result); 

21 $sql2-"select admin from $table members where name-'$ COOKIE[user]"; 

22 S$result22mysq! query($sql2,Slink) or die(mysql error()); 

23 $rows2-mysql fetch array(Sresult2); 

24 if((Srows[0]-$ COOKIE[user?) or ($rows2[0]«3)) /如果 用 户 不 是 发 帖 者 或 者 不 是 管理 员 
25 { 

26 echo "<h2> 没 有 这 样 的 权限 </h2>"; 

27 echo "<h3> 点 <a href=\"#\" onclick=\"history.go(-1)"> 这 里 </a> 返 回 </h3>"; 

28 exit(); 

29 } 

30 else 

31 { 

32 if(l$ POSTT[title]) // 如 果 没 有 发 送 标题 ， 显 示 HTML 
33 { 

34 echo "<script language=\"javascript\">"; 

35 echo "function juge(theForm)"; 

36 echo "("; 

37 echo "if (theForm.title.value == \"\")"; 

38 echo "(*; 

39 echo "alert(\" 请 输入 主题 名 称 !\");"; 

40 echo "theForm.title.focus();"; 

41 echo "return (false);"; 

42 echo "j^; 

43 echo "if (theForm.content.value == \"\")"; 

44 echo "("; 

45 echo "alert(\" 请 输入 主题 内 容 ! \");"; 

46 echo "theForm.content.focus();"; 

47 echo "return (false);"; 

48 echo "}"; 

49 echo "}"; 

50 echo "</script>"; 

51 echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">"; 

52 echo "<tr>"; 

53 echo "<td>"; 

54 echo "<center><h2> 编 辑 帖 子 </h2></center>"; 

55 echo "</td>"; 

56 echo "</tr>"; 

57 echo "</table>"; 

58 $sql t-"selectp id,topic name from $table topic where id-'$rows[topic id)"; 
59 $result t»mysql query($sql t,Slink) or die(mysql error()); 

60 $rows t-mysql fetch array(S$result t); 

61 echo "<table width 8096" cellpadding=\"1\" cellspacing=\"1\">"; 

62 echo "<tr>"; 

63 echo "<td><a href=20-5.php> 论 坛 首页 </a>|<a href-20-6.php?id-".$rows t[0]."» 3E i& 
坛 </a>|<a href=20-7.php?id=".$rows['topic_id'].">".$rows_t[1]."</a></td>"; 

64 echo "</tr>"; 

65 echo "</table>"; 

66 echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">"; 

67 echo "<form method=\"post\ action=\"20-12.php?id=".$_ GET[id'."" onsubmit- 


\"return juge(this)\">"; 
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68 
69 
70 
71 
72 
73 
74 
75 
76 
77 
<hd>"; 
78 
79 
80 


echo "<tr>"; 
if(Srows[re id]==0) $re id-$ GET['id']; /如果 帖 子 是 主题 
else $re_id=$rows[re_id]; /如 果 帖 子 不 是 主题 


echo "<input type=\"hidden\" name=\"re_id\" value=\V".$re id." "»"; 

echo "<td> 输 入 标题 : </td>"; 

echo "<td><input type=\"text\" name=\"title\" value=\"".$rowsf'title']."\"></td>"; 

echo "</tr>"; 

echo "<tr>"; 

echo "<td> 输 入 内 容 : </td>"; 

echo "<td><textarea rows=5 cols=50 name=\"contenf\">".$rows['content]. "</textarea> 


echo "</tr>"; 
echo "<tr>"; 
echo "<td colspan=\"2\"><center><input type=submit value= 提 交 ><input type=reset 


value= 重 置 ></center></td>"; 


如 果 想 对 哪 一 


echo "</tr>"; 
echo "<form>"; 
echo "</table>"; 
echo "</center>"; 
echo "</body>"; 
echo "</html>"; 


// 如 果 内 容 已 经 提交 


Stitle-$ POSTT title; 

$content-$ POST[content'; 

$id-$ GET['id"]; 

$re id-$ POST[re id; 

$sql="update $table posts set title='$title',content='$contentť where id-'$id"; 
if(mysql_query($sql,$link)) // 如 果 更 新 语句 顺利 执行 


echo "编辑 帖子 成 功 ， 现 在 返回 主题 显示 页 "; 
echo "<meta http-equiv=\"refresh\" content=\"2; url=20-9.php?id=".$re_id."\">"; 


} 
else 

echo "编辑 记录 时 出 错 ， 现 在 返回 "; 

echo "<meta http-equiv=\"refresh\" content=\"2; url-20-9.php?id-".$re id.^"»"; 
H 


条 记录 进行 编辑 ， 单 击 图 20.23 某 一 条 帖子 标题 后 面 的 “编辑 ”链接 即 可 。 当 然 ， 前 


提 是 要 有 权限 。 如 果 没 有 相应 的 权限 ， 也 不 会 显示 出 “编辑 ”链接 。 但 是 有 可 能 存在 恶意 的 使 用 者 通 
过 猜想 直接 在 地 址 栏 中 运行 ， 所 以 还 要 在 编辑 页 里 进行 用 户 身份 的 判断 。 如 果 是 不 合法 用 户 请 求 编辑 
页 ， 就 会 出 现 如 图 20.24 所 示 的 提示 。 

这 里 以 管理 员 身 份 登录 ， 编 辑 如 图 20.23 所 示 的 一 条 回复 。 单 击 “ 编 辑 ” 链 接 后 ， 出 现 如 图 20.25 
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所 示 的 执行 结果 。 


Es [E3875 7) 
[€] wahai Pr O | San * rox 
REEF 
RZEZ | 主 这 坛 |PHB 综 程 
rj 
m WAFA: [党 一 东 列 试 信息 
@ [Or —€— 
WANE. 
没有 这 样 的 权限 
EI 22 |s 
Rl00% 7 Max - 
图 20.24 ”非法 用 户 请 求 编辑 页 执行 结果 图 20.25 合法 用 户 请 求 编辑 页 执行 结果 


在 这 里 可 以 对 帖子 的 标题 及 内 容 进 行 修改 ， 修 改 完成 后 直接 单 击 “提交 ”按钮 即 可 。 这 里 把 帖子 
内 容 修 改 为 与 PHP 编程 有 关系 的 内 容 , 这 样 也 符合 PHP 编程 区 内 容 的 要 求 。 提交 操 作 , 如 果 正 确 执行 ， 
程序 将 会 返回 到 主题 显示 页 。 执 行 操作 后 的 主题 显示 页 如 图 20.26 所 示 。 
[em 


人 也 B o/feshowzsdwwa Pr Ò | S s723 ua 


主题 显示 


论坛 首页 | 主 论坛 |PHP 验 程 发 表 新 主题 | 发 表 回 复 
作者 ，admin | 
作者 ID，1 

作者 IP，127.0.0.1 

标题 ， 最 简单 的 PHP 程 序 dedi. 

AE: echo "hello world!"; 

发 表 时 间 ，2013 年 05 月 16 日 12，17，27 
以 下 为 该 主题 的 回复 

| 作者 ，Tom 


ID: 1 

作者 ITP，127.0.0.1 

标题 , 很 好 编辑 

内 容 : 你 写 的 内 容 很 好 ! 

发 表 时 间 ，2013 年 05 月 16 日 15，20，52 
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图 20.26 执行 修改 操作 后 的 主题 显示 页 
从 图 20.26 可 以 得 知 经 过 操作 ， 帖 子 内 容 及 标题 已 经 被 成 功 修改 。 


20.7.2 ”删除 帖子 


GER 知识 点 讲解 : 光盘 \ 视 频 讲 解 \ 第 20 章 \ 删 除 帖子 .wmv 

有 时 ， 只 是 单纯 地 编辑 帖子 并 不 能 满足 要 求 ， 因 为 总 是 有 别有用心 的 人 会 在 论坛 中 放 很 多 垃圾 帖 。 
有 时 是 无 用 的 恶意 广告 帖 ， 有 时 是 色情 网 站 链接 帖 ， 有 时 则 含有 违反 国家 法 律 、 法 规 内 容 的 帖子 ， 对 
于 这 一 类 帖子 必须 给 予 删除 。 本 小 节 来 介绍 如 何 删除 帖子 。 
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在 进行 删除 操作 之 前 同 编辑 帖子 一 样 ， 也 需要 对 论坛 的 主题 显示 页 做 一 下 改动 。 在 20.7.1 小 节 加 
入 编辑 链接 的 后 面 再 跟 上 删除 链接 。 具 体 如 下 : 


if($rows t[admin]-73) 
echo "<a href=\"20-13.php?id=".$rows[id]."\">| 删 除 </a>"; 


上 面 这 段 代 码 实现 的 功能 是 : 先 判断 用 户 身份 ， 如 果 用 户 是 管理 员 则 显示 “删除 ”链接 。 这 样 就 
确保 只 有 管理 员 才能 单 击 相应 的 链接 。 修 改 后 主题 的 显示 结果 如 图 20.27 所 示 。 


[Euer] 
[€] 18 htip://localhost/20-9.pghp7id=1 


1 in KALE 


XUuzBm|xiz|PHPde 发 表 新 主题 | 发 表 回复 


作者 Ip，127.0.0.1 

标题 ， 最 简单 的 PHP 程 序 iei [li 

AE: echo "hello world!"; 

发 表 时 间 ，2013 年 05 月 16 日 12，17，27 
以 下 为 该 主题 的 回复 

作者 ; Tom 

作者 ID，1 

作者 IJP，127.0.0.1 

标题 , 很 好 BAI 

内 容 ; 你 写 的 内 容 很 杂 ! 

发 表 时 间 ，2013 年 05 月 16 昌 15: 20. 52 


*10x v 
图 20.27 加 入 “删除 ”链接 的 主题 显示 结果 
做 完 准 备 工 作 ， 下 面 就 来 介绍 如 何 对 帖子 进行 删除 操作 。 这 里 还 要 分 两 种 情况 : 一 种 是 被 删除 的 
是 非 主题 ， 这 种 情况 很 好 办 ， 直 接 删除 记录 即 可 ;另外 一 种 情况 是 删除 的 记录 是 主题 。 这 就 比较 麻烦 
了 ， 因 为 主题 通常 都 有 回复 ， 所 以 不 仅 要 对 帖子 记录 本 身 进 行 操作 ， 还 要 对 主题 的 回复 进行 操作 。 
技巧 : 这 里 采用 这 样 的 处 理 机 制 : 如 果 删 除 的 帖子 本 身 是 主题 就 查找 它 的 所 有 回复 ， 把 第 一 条 对 主题 


的 回复 变 为 主题 ， 原 来 对 原 主 题 的 回复 都 变 为 对 新 主题 的 回复 。 听 起 来 好 像 很 复杂 ， 实 际 上 并 
不 复杂 。 


如 有 一 个 主题 ， “1”。 其 下 有 3 个 回复 “1-1”、“1-2”、“1-3”。 则 删除 主题 “1”， 原 来 的 
回复 “1-1” 就 成 为 新 的 主题 ， 而 “1-2”、“1-3” 则 成 了 对 新 主题 的 回复 。 
【实例 20-13】 以 下 为 删除 帖子 的 代码 。 


€ | 实例 20-13: 删除 帖子 
源码 路 径 光盘 \ 源 文件 20\20-13.php 


01 <?php 

02 echo "<html>"; 

03 echo "<head>"; 

04 echo "<title> 删 除 帖子 </title>"; 
05 echo "</head>"; 

06 echo "<body>"; 
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07 echo "<LINK href=\"style.css\" rel=stylesheet>"; 

08 echo "<center>"; 

09 ifl$ GET[id]) 

10 { 

11 echo "<h2> 没 有 请 求 ID</h2>"; 

12 echo "<h3> 点 <a href=20-5.php> 这 里 </a> 返 回 </h3>"; 

13 exit(); 

14 ) 

15 else 

16 { 

ir require "20-1.php"; 

18 $sql="select admin from $table members where name='$_COOKIE[user]"; 
19 $result=mysql_query($sql,$link) or die(mysql_error()); 

20 $rows=mysql_fetch_array($result); 

21 if(Srows[0]«3) 

22 i 

23 echo "<h2> 没 有 这 样 的 权限 </h2>"; 

24 echo "<h3> 点 <a href=\"#\" onclick=\"history.go(-1)"> 这 里 </a> 返 回 </h3>"; 
25 exit(); 

26 ) 

27 else 

28 { 

29 $sql="select re id from $table_posts where id-'$ GET[id]"'; 

30 S$resultzmysql query(S$sql,Slink) or die(mysql error()); 

31 $rows-mysql fetch array(Sresult); 

32 if(Srows['re id']--0) 

33 { 

34 $sql2="select id from $table posts where re id-'$ GET[id] limit 1"; 
35 $result22mysql query($sql2,Slink); 

36 $rows2-mysql fetch array(Sresult2); 

37 $sql3-"update Stable posts set re id-'0' where id-'$rows2[0]"; 
38 mysql query($sql3,Slink); 

39 $sql4-"update $table posts setre id-'$rows2[0] where re id-'$ GET[id]"; 
40 mysql query($sql4,Slink); 

41 ) 

42 $sql-"delete from $table posts where id='$_GET[idj"; 

43 if(mysql query($sql.Slink)) 

44 { 

45 echo "删除 帖子 成 功 ， 现 在 返回 论坛 首页 "; 

46 } 

47 else 

48 { 

49 echo "删除 记录 时 出 错 ， 现 在 返回 论坛 首页 "; 

50 } 

51 echo "<meta http-equiv=\"refresh\" content=\"2; url=20-5.php\">"; 

52 ) 

53 ) 

54 ?> 


单 击 图 20.27 中 的 “删除 ”链接 ， 就 相当 于 执行 以 上 代码 。 同 理 ， 这 个 页 面 也 需要 对 用 户 的 身份 进 
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行 验证 ， 必 须 是 管理 员 才 能 进行 这 项 操作 。 如 果 普 通用 户 或 者 匿名 用 户 执行 这 个 页 面 ， 则 会 出 现 与 
图 20.24 类 似 的 提示 页 。 而 如 果 是 有 权限 的 管理 员 单 击 链接 ， 则 会 执行 相关 的 删除 操作 。 删除 主题 后 的 
主题 页 面 如 图 20.28 所 示 。 


Eee) 
[€] T S wa EE B n^ xi 


E: 2j 


BAI PHP 发 到 新 主题 | 发 表 回复 


作者 IP，127.0.0.1 

Tum. 很 村 AEN 

内 容 ， 你 配 的 内 容 很 李 ! 

发 表 时 间 : 2013 年 05 月 166 15: 20. 52 


以 下 为 该 主题 的 四 复 


Rios v 


图 20.28 ”删除 主题 后 的 显示 
可 以 看 到 ， 原 来 的 回复 变 成 了 新 的 主题 ， 说 明 删除 操作 成 功 。 


20.7.3 SRE 


GA 知识 点 讲解 : 光盘 \ 视 频 讲 解 \ 第 20 ARE Eom 

什么 是 掘 墓 呢 ? 在 分 论坛 显示 页 中 ， 显 示 的 是 各 个 主题 的 基本 内 容 。 排 列 顺序 是 按照 回复 的 先后 
顺序 进行 排列 的 。 这 样 可 以 使 得 用 户 最 后 回复 的 帖子 始终 处 于 最 上 方 ， 使 其 他 用 户 能 够 第 一 时 间 浏 览 
到 这 个 帖子 及 回复 ， 如 图 20.29 所 示 。 


[LE 一 
(E S hroaz D + Ò |9 sess 四 
分 论坛 首页 
论坛 首页 | 主 论坛 AREE 


标题 作者 ERE BER 景 后 发 表 
fit Tom 0 0 201305316915: 20. 52 
test Tom 0 2 201305416815; 07. 05 


第 -页 | 上 一 页 | 下 一 页 | 最 后 页 


Kios ~ 


图 20.29 最 后 回复 的 帖子 显示 于 最 上 方 
这 一 设 定 本 来 是 为 了 方 使 用 户 能 够 及 时 发 现 最 新 的 帖子 的 ， 但 这 样 就 会 存在 一 些 问 题 ， 会 有 一 些 
用 户 对 很 久 以 前 的 老 帖 进行 回复 。 这 样 一 来 ， 老 主题 就 会 显示 在 分 论坛 页 面 最 醒目 的 位 置 。 网 络 上 通 
常 对 这 种 恶意 回复 老 帖 的 行为 叫做 掘 墓 。 
技巧 : 如 何 防止 振 莫 行为 发 生 呢 ?比较 可 行 的 方法 就 是 先 设 定 一 个 最 大 允许 回复 天 数 。 如 这 一 天 数 设 
为 “5”。 如 果 主 题 留言 时 间 是 在 5 天 以 前 ， 那 么 就 不 允许 对 这 一 主题 进行 回复 ， 这 样 就 可 以 有 
效 避免 振 莫 行为 的 发 生 。 


(m, 
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这 要 求 在 对 帖子 进行 回复 时 先 判 断 是 否 已 经 超过 了 最 大 允许 回复 天 数 。 如 果 超 过 了 ， 就 给 出 不 允许 
回复 的 提示 。 这 就 要 对 实例 20-8 的 代码 进行 修改 。 因 为 这 个 文件 是 发 表 主 题 或 者 回复 时 要 用 到 的 页 面 。 

下 面 给 出 具体 修改 措施 。 

找到 以 下 内 容 : 

ifl$ GET[re id]) $re_id=0; 

else $re id-$ GET[re id]; 

在 这 些 内 容 下 面 添加 如 下 内 容 : 


function next7($y,$m,$d) 
d 


St"01"]-$1[03"]-St"05"]-$1[07"]-$1"08"]-$1[10"]-$1"12"]-31; 
$["02"]-28; 
St["04"]-$t["06"]-St["09"]-St["1 1"]-30; 
if($d+5<=$t[$m]) $d=$d+5; 
else 
{ 
$d=$d+5-$t[$m]; 
$m=$m+1; 
if(strlen($m)==1) $m="0".$m; 
if($m»12) $y=$y+1; 
H 
if(strlen($d)==1) $d-"0".$d; 
retum($y.$m.$d); 
) 
if(Sre id!-0) 
{ 
$sql="select post time from $table posts where id-'$re id"; 
$result-mysql query($sql); 
$rows-mysql fetch array($result); 
S$last-next7(substr($rows[post time],0,4),substr($row[post time],6,2),substr($row[post time], 10,2)); 
S$tempz-date(Ymd); 
if($last<$temp) 
{ 
echo "已 经 超过 5 天 了 ， 你 还 回复 什么 ? !"; 
echo "<br> 点 <a href=i=20-7.php?id=".$topic_id."> 这 里 </a> 返 回 "; 
exit(); 


} 

这 里 首先 定义 了 一 个 函数 next70， 这 一 函数 的 作用 就 是 求 某 一 天 后 5 天 是 哪 一 天 ， 然 后 读 取 要 回 
复 的 主题 的 日 期 ， 截 取出 整数 ， 再 求 其 5 天 后 是 多 少 ， 把 值 赋 给 $last 变量 ， 再 与 代表 当前 日 期 的 变量 
Stemp 相 比 较 。 如 果 $last 小 于 $temp， 则 给 出 出 错 提示 ， 并 且 中 止 所 有 操作 。 

经 过 上 述 处 理 ， 用 户 的 恶意 掘 墓 行为 就 会 得 到 有 效 的 控制 。 

关于 帖子 的 管理 ， 本 节 就 介绍 到 这 里 。20.8 节 将 介绍 论坛 用 户 的 管理 。 
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一 个 用 户 在 注册 一 个 论坛 后 ， 他 的 各 项 信息 ， 包 括 密 码 、 昵 称 、 性 别 、 电 子 信箱 、 图 像 、 签 名 等 
内 容 都 是 可 以 改变 的 。 通 常 这 些 操作 也 都 是 由 用 户 自行 完成 的 。 本 节 就 来 讲 如 何 实现 用 户 的 管理 。 


20.8.1 用 户 信息 的 显示 


(E 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 20 章 \ 用 户 信息 的 显示 .wmv 

用 户 与 用 户 之 间 都 应 该 能 够 互相 查看 对 方 的 注册 信息 。 在 显示 主题 时 ， 为 帖子 的 作者 一 项 加 上 指 
向 该 用 户 信息 显示 页 的 超 链接 以 实现 不 同 用 户 间 的 互相 查看 。 

这 里 就 需要 对 20-9.php 做 一 点 修改 。 找 到 如 下 的 内 容 : 

echo "作者 : ".$rows[poster]; 

把 它 修改 为 : 

echo "作者 : «a href=20-14.php?id=".$rows[poster_id].">".$rows[poster]."</a>"; 

经 过 这 样 的 修改 ， 原 本 只 显示 的 用 户 名 ， 现 在 有 了 一 个 指向 查看 用 户 信 息 页 面 的 超 链接 。 

下 面 就 如 何 显示 用 户 信息 为 读者 做 一 介绍 。 操 作 过 程 只 需 获取 参数 $_GET[id]， 然 后 从 用 户 表 中 搜 
索 相 关 记 录 ， 显 示 出 相关 信息 即 可 。 

【实例 20-14】 以 下 为 显示 用 户 信 息 的 代码 。 

E [ ONE 实例 20-14: 显示 用 户 信息 o 


源码 路 径 ， 光盘 \ 源 文件 20\20-14.php 


01 <?php 

02 echo "<html>"; 

03 echo "<head>"; 

04 echo "<title> 显 示 用 户 信息 </title>"; 

05 echo "</head>"; 

06 echo "<body>"; 

07 echo "<LINK href=\"style.css\" rel-stylesheet»"; 

08 echo "<center>"; 

09 ifi$ GET[id7) 

10 { 

11 echo "<h2> 没 有 请 求 ID</h2>"; 

12 echo "<h3> 点 <a href=# onclick=history.go(-1)> 这 里 </a> 返 回 </h3>"; 
13 exit(); 

14 H 

15 else 

16 ( 

17 require "20-1.php"; 

18 $sql-"select * from $table members where id-'$ GET[id]"; 
19 $resultzmysql! query(Ssql,Slink) or die(mysql error()); 

20 $rows-mysql fetch array($result); 


21 
22 
23 
24 
25 
26 
27 
28 
29 
30 
31 
32 
33 
34 
35 
36 
37 
38 
39 
40 
41 
42 
43 
44 
45 
46 
47 
48 
49 
50 
51 
52 
53 
54 
55 
56 
57 
58 
59 
60 
61 
62 
63 
64 
65 
66 
67 
68 
69 
70 
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echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">"; 

echo "<tr>"; 

echo "<td>"; 

echo "«center»«h2» i RA P1" Srows['name'].4& & «/h2» «/center»"; 

echo "</td>"; 

echo "</tr>"; 

echo "</table>"; 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">"; 

echo "<tr>"; 

echo "<td>"; 

echo "<a href=\"20-5.php\"> 论 坛 首 页 </a>"; 

echo "«/td»"; 

if($rows['name']==$_ COOKIE[user]) 

í 
echo "<td align=\"right\">"; 
echo "<a href-"20-15.php?id-" $rows[id']." "4858 5 & «/a» |"; 
echo "<a href=\"20-16.php?id=".$rows[id1."\"> 修 改 密码 </a>"; 
echo "</td>"; 

n 

echo "</tr>"; 

echo "</table>"; 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">"; 

echo "<tr>"; 

echo "<td> 用 户 名 : </td>"; 

echo "<td>".$rows|'name')."</td>"; 

echo "</tr>"; 

echo "<tr>"; 

echo "<td> 用 户 昵称 : </td>"; 

echo "<td>".$rows|'nickname')."</td>"; 

echo "</tr>"; 

echo "<tr>"; 

echo "<td> 性 别 : </td>"; 

echo "«td»".$rows['sex']."«/td»"; 

echo "</tr>"; 

echo "<tr>"; 

echo "<td> 电 子 信箱 : «/td»"; 

echo "<td>".$rows['email]."</td>"; 


echo "</tr>"; 
echo "<tr>"; 
echo "<td> 用 户 图 像 </td>"; 
echo "<td>"; 


if(Srows[photo']) echo "<img src=images/". $rows['photo].">"; 
else echo "该 用 户 没有 设置 图 像 "; 

echo "</td>"; 

echo "</tr>"; 

echo "<tr>"; 

echo "<td> 签 名 : </td>"; 

echo "<td>"; 

if($rows['q_name') echo $rows[q_name]; 

else echo "该 用 户 没 有 设置 签名 档 "; 

echo "</td>"; 
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72 echo "</tr>"; 

73 echo "<tr>"; 

74 echo "<td> 发 帖 数量 : </td>"; 

75 echo "«td»".$rows[post num7."«/td»"; 
76 echo "</tr>"; 

TT echo "<tr>"; 

78 echo "<td> 注 册 日 期 : </td>"; 

79 echo "<td>".$rows[reg_date]."</td>"; 
80 echo "</tr>"; 

81 echo "</table>"; 

82 echo "</center>"; 

83 echo "</body>"; 

84 echo "</html>"; 

85 } 

86 ?> 


在 PHP 环境 下 执行 该 文件 ， 如 果 是 匿名 用 户 浏览 某 用 户 的 信息 ， 执 行 结果 如 图 20.30 所 示 。 
从 图 20.30 的 执行 结果 可 以 看 到 页 面 只 显示 出 了 用 户 的 基本 信息 。 如果 某 用 户 查 看 自己 的 信息 , 执 
行 结果 会 有 所 不 同 ( 见 图 20.31) 。 


e EE OY [c] OE A 
显示 用 户 admin 信 息 显示 用 户 admin 信 息 
论坛 首页 论坛 首页 编辑 信息 | 修改 市 码 
用 户 名 ， admin AFE admin 
LS Tom LI Tom 
il: boy tih boy 
电子 信箱， admin@admin.com 电子 信箱 ， admin&admin.com 
AFE 该 用 户 没有 设置 图 像 RAPES WAPENZI 
EID 该 用 户 役 有 设置 签名 档 签名 ， UM RARESA 
dg. 2 发 贴 效 量 ， 2 
注册 日 期 20135058168 HEBES 201355058168 
uo ~ Kiom v 
图 20.30 匿名 用 户 浏览 其 他 用 户 信息 执行 结果 图 20.31 注册 用 户 查看 自己 信息 


可 以 看 到 ， 注 册 用 户 查看 自己 的 信息 会 显示 出 指向 编辑 信息 与 修改 密码 页 面 的 链接 ， 用 户 可 以 通 
过 这 些 链 接 修 改 自己 的 信息 及 密码 。 
20.8.2 小 节 就 来 介绍 如 何 使 用 户 能 够 修改 自己 的 注册 信息 。 


20.82 ”普通 信息 的 修改 


(OU 知识 点 讲解 :光盘 \ 视 频 讲 解 \ 第 20 章 \ 普 通信 息 的 修改 .wmv 

本 小 节 来 介绍 如 何 使 用 户 能 够 修改 自己 的 普通 信息 。 当 然 , 用 户 也 不 能 随意 修改 自己 的 所 有 信息 ， 
如 用 户 名 、 发 帖 数 、 注 册 日 期 、 管 理 员 等 级 等 ， 用 户 可 以 修改 的 只 有 用 户 昵称 、 性 别 、 电 子 信箱 、 论 
坛 图 像 、 发 帖 个 性 签名 等 。 下 面 就 来 介绍 如 何 实现 对 用 户 这 些 信息 的 修改 。 

【实例 20-15】 以 下 为 修改 用 户 信息 代码 。 


e. 
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实例 20-15: 修改 用 户 信息 
源码 路 径 : 光盘 \ 源 文件 20\20-15.php 


01 <?php 

02 echo "«html»"; 

03 echo "<head>"; 

04 echo "<title> 修 改 用 户 信息 </title>"; 

05 echo "</head>"; 

06 echo "<body>"; 

07 echo "<LINK href=\"style.css\" relzstylesheet»"; 

08 echo "<center>"; 

09 if(0$ GET[id']) 

10 ( 

11 echo "<h2> 没 有 请 求 ID</h2>"; 

12 echo "<h3> 点 <a href=# onclick=history.go(-1)> 这 里 </a> 返 回 </h3>"; 
13 exit(); 

14 ) 

15 else 

16 { 

17 require "20-1.php"; 

18 $sql-"select * from $table members where id-'$ GETR[id]"'; 

19 S$resultzmysql query(S$sql,Slink) or die(mysql error()); 

20 $rows-mysql fetch array(Sresult); 

21 if($Srows[name!-$ COOKIE[user]) 

22 ( 

23 echo "<h2> 请 求 ID 与 用 户 身份 不 符 ! </h2>"; 

24 echo "<h3> 点 <a href=# onclick=history.go(-1)> 这 里 </a> 返 回 </h3>"; 
25 exit(); 

26 ) 

27 else 

28 ( 

29 echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">"; 
30 echo "<tr>"; 

31 echo "<td>"; 

32 echo "<center><h2> 修 改 用 户 ".$rows[name1]." 信 息 </h2></center>"; 
33 echo "</td>"; 

34 echo "</tr>"; 

35 echo "</table>"; 

36 echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">"; 
37 echo "<tr>"; 

38 echo "«td»"; 

39 echo "<a href=\"20-5.php\"> 论 坛 首 页 </a>"; 

40 echo "</td>"; 

41 echo "<td align=\"right\">"; 

42 echo "<a href=\"20-14.php?id=".$rows[id1."\"> 显 示 信 息 </a>|"; 
43 echo "<a href=\"20-16.php?id=".$rows[id1."\"> 修 改 密码 </a>"; 
44 echo "</td>"; 

45 echo "</tr>"; 

46 echo "</table>"; 

47 ifISPOST[$nickname]) 

48 { 
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echo "<script language-' javascript" 2"; 

echo "function juge(theForm)"; 

echo "("; 

echo "if (theForm.nickname.value == \"\")"; 

echo "{"; 

echo "alert(\" 请 输入 昵称 ! Vy" 

echo "theForm.title.focus();"; 

echo "return (false);"; 

echo "^; 

echo "^ 

echo "function s photo(the)"; 

echo "{"; 

echo "document.img.src-'images/^the.photo.value*'.bmp*";"; 
echo "}"; 

echo "</script>"; 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">"; 
echo "«form method=\"post\" action=\"20-15.php?id=".$_GETTid].\"” onsubmit- 


echo "<tr>"; 

echo "<td> 用 户 昵称 : </td>"; 

echo "<td>"; 

echo "<input type=\"text\" name=\"nickname\" value=\"".$rows['nickname']."\">"; 
echo "</td>"; 

echo "</tr>"; 

echo "<tr>"; 

echo "<td> 性 别 :</td>"; 

echo "<td>"; 

echo "<input type=\"radio\" name=\"sex\" value=\"boy\" "; 
if(Srows['sex']-7"boy") echo " checked "; 

echo "> 男 "; 

echo "<input type=\"radio\" name=\"sex\" valuezVgirlV" "; 
if($rows['sex']: irl") echo " checked "; 

echo "» X"; 

echo "</td>"; 

echo "</tr>"; 

echo "<tr>"; 

echo "<td> 电 子 信箱 : </td>"; 

echo "<td>"; 

echo "<input type=\"text\" name \"email\" value=\"". $rows[email].\">"; 
echo "</td>"; 


echo "</tr>"; 
echo "<tr>"; 
echo "<td> 用 户 图 像 </td>"; 
echo "<td>"; 


echo "<select name=\"photo\" size=\"1\" onchange=\"s_photo(this.form)\">"; 
for($i=1;$i<21;$i++) 


ü 

echo "<option value=".$i.">".$i."</option>";; 
} 
echo "</select>"; 


if(ISrows['photo']) 
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99 { 

100 echo "用 户 没有 设置 图 像 <br>"; 

101 echo "<img src=\"images/1.bmp\" name=\"img\">"; 
102 } 

103 else 

104 { 

105 echo "<img src-'images/".$rows[photo'].^" name=\"img\">"; 
106 } 

107 echo "</td>"; 

108 echo "</tr>"; 

109 echo "<tr>"; 

110 echo "<td> 答 名 : </td>"; 

111 echo "<td>"; 

112 echo "<input type-l'text" name Y'q name!" valuezV".$rows[q. name7.""»"; 
113 echo "</td>"; 

114 echo "</tr>"; 

115 echo "<tr>"; 

116 echo "<td colspan=\"2\"><center>"; 

117 echo "<input type=submit value=\" 提 交 \>"; 

118 echo "</center></td>"; 

119 echo "«/tr»"; 

120 echo "</form>"; 

121 echo "</table>"; 

122 echo "</center>"; 

123 echo "</body>"; 

124 echo "«/html»"; 

125 ) 

126 else 

127 t 

128 $nickname-$ POST[nicknameT; 

129 $sex-$ POST[sex]; 

130 | POST['email]; 

131 | POST[photo']; 

132 $q name-$ POST[q name'; 

133 $id-$ GETI id; 

134 $sql="update $table members set nickname-'$nickname',sex-'$sex',email-'Semail', 
photo-'$photo'q name-'$q name' where id: 时 

135 if(mysql_query($sql,$link)) 

136 n 

137 echo "修改 注册 信息 成 功 ， 现 在 返回 查看 信息 页 "; 
138 echo "<meta http-equiv=\"refresh\" content=\"2; url-20-14.php?id-" Sid." "»"; 
139 ) 

140 else 

141 { 

142 echo "修改 注册 信息 失败 ， 现 在 返回 修改 用 户 记录 页 "; 
143 echo "<meta http-equiv=\"refresh\" content=\"2; url=20-15.php?id=".$id."\">"; 
144 } 

145 } 

146 } 

147 H 

148 ?> 


© 


EM LL 


单 击 图 20.31 中 的 “编辑 信息 ” 超 链 接 ， 就 可 以 执行 该 文件 ， 


执行 结果 如 图 20.32 所 示 。 
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2032 ”修改 用 户 信息 执行 结果 


这 里 只 按照 需要 对 需要 改动 的 内 容 进行 更 改 。 然 后 单 击 “ 提 交 ” 按 钮 ， 就 可 以 把 修改 信息 提交 到 
后 台 进 行 处 理 。 如 果 操作 正确 执行 ， 新 的 用 户 信息 将 代替 以 前 的 信息 。 


20.8.3 用户 密码 的 修改 


名 知识 点 讲解 : 光 瘟 \ 视 频 讲解 \ 第 20 章 \ 用 户 密码 的 修改 .wmv 
密码 是 一 个 比较 特殊 的 用 户 信息 ， 它 是 用 户 登录 系统 的 最 重要 的 “钥匙 ”， 所 以 要 把 对 密码 的 修 
改 与 普通 信息 的 修改 分 开 来 进行 。 


技巧 : 密码 修改 的 机 理 : 先 让 用 户 分 别 输入 旧 密 码 及 新 的 密码 ， 然 后 在 后 台 进 行 判断 。 如 果 用 户 输入 


【实例 20-16】 以 下 为 修改 用 户 密码 的 代码 。 


echo "<title> 修 改 用 户 密码 </title>"; 


echo "<LINK href=\"style.css\" rel=stylesheet>"; 


echo "<h2> 没 有 请 求 ID</h2>"; 
echo "<h3> 点 <a href=# onclick=history.go(-1)> 这 里 </a> 返 回 </h3>"; 


的 旧 密 码 与 库 里 保存 的 一 致 ， 则 执行 把 旧 密 码 更 改 为 新 密码 的 SQL 语句 。 反 之 ， 
不 一 致 则 给 出 出 错 提示 。 


如 果 用 户 输入 
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else 
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require "20-1.php"; 

$sql="select * from $table members where id-'$ GETR[id]"; 
S$result-mysq! query($sql,Slink) or die(mysql error()); 
$rows-mysql fetch array(Sresult); 

if(Srows['name'-$ COOKIE[user]) 


else 


echo "<h2> 请 求 ID 与 用 户 身份 不 符 ! </h2>"; 
echo "<h3> 点 <a href=# onclick=history.go(-1)> 这 里 </a> 返 回 </h3>"; 
exit(); 


echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">"; 
echo "<tr>"; 

echo "<td>"; 

echo "<center><h2> 修 改 用 户 ".$rows[name1]." 的 密码 </h2></center>"; 
echo "</td>"; 

echo "</tr>"; 

echo "</table>"; 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">"; 
echo "<tr>"; 

echo "<td>"; 

echo "<a href=\"20-5.php\"> 论 坛 首页 </a>"; 

echo "</td>"; 

echo "<td align=\"right\">"; 

echo "<a href=\"20-14.php?id=".$rows['id1."\"> 显 示 信 息 </a>|"; 
echo "<a href=\"20-15.php?id=".$rows[id]."\"> 修 改 信息 </a>"; 


echo "</td>"; 

echo "</tr>"; 

echo "</table>"; 

if(IS8 POST[password']) 

t 
echo "<script language" javascript" 7"; 
echo "function juge(theForm)"; 
echo "("; 
echo "if (theForm.password.value == V)"; 
echo "("; 


echo "alert(\" 请 输入 旧 密 码 ! \");"; 

echo "theForm.password.focus();"; 

echo "return (false);"; 

echo ")"; 

echo "if (theForm.newpassword.value == VY)"; 
echo "("; 

echo "alert(\" 请 输入 新 密码 ! Vi": 

echo "theForm.newpassword.focus();"; 

echo "return (false);"; 

echo ")"; 

echo "if (theForm.newpassword.value.length «8)"; 
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\"return juge(this)\">"; 
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else 


echo "{"; 

echo "alet 3384€ 8 位 以 上 ! V)" 

echo "theForm.newpassword.focus();"; 

echo "return (false);"; 

echo "^; 

echo "if (theForm.newpassword.value != theForm.repassword.value)"; 
echo "(*; 

echo "alert(\" 重 复 输入 的 密码 不 一 致 ! \");"; 

echo "theForm.repassword.focus();"; 

echo "return (false);"; 

echo "^; 

echo "^ 

echo "</script>"; 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">"; 
echo "<form method=\"post\" action=\"20-15.php?id=".$_GET[id].\"” onsubmit- 


echo "<tr>"; 

echo "<td> 输 入 旧 密 码 : </td>"; 

echo "<td>"; 

echo "<input type=\"password\" namez- password"; 
echo "</td>"; 

echo "</tr>"; 

echo "<tr>"; 

echo "<td> 输 入 新 密码 : </td>"; 

echo "«td»"; 

echo "<input type-l password!" name=\"newpassword\">"; 
echo "</td>"; 

echo "</tr>"; 

echo "<tr>"; 

echo "<td> 再 输入 一 次 : </td>"; 

echo "«td»"; 

echo "<input type-l password!" name=\"repassword\">"; 
echo "</td>"; 

echo "</tr>"; 

echo "<tr>"; 

echo "<td colspan=\"2\"><center>"; 

echo "<input type=submit value=\" 提 交 V>"; 

echo "</center></td>"; 

echo "</tr>"; 

echo "«/form»"; 

echo "</table>"; 

echo "</center>"; 

echo "</body>"; 

echo "</html>"; 


$password-md5($ POST[password']); 

$newpassword-md5($ POST[newpassword'); 

Sid-$ GET['id"; 

$sql-"select id from $table members where name-'$ COOKlE[userl and 
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password='$password"; 


115 $result=mysql_query($sql,$link); 

116 $nums-mysq| num rows(Sresult); 

117 if($nums«1) 

118 t 

119 echo "输入 的 用 户 密码 错误 ! <p>"; 

120 echo "请 重新 输入 ! "S 

121 echo "<meta http-equiv=\"refresh\" content=\"2; url=20-16.php?id=".$id.\">"; 
122 } 

123 else 

124 ( 

125 $sql-"update $table members set password='$newpassword' where id-'$id'"; 
126 if(mysql query($sql,Slink)) 

127 t 

128 echo "修改 用 户 密码 成 功 ， 现 在 返回 查看 信息 页 "; 

129 echo "<meta http-equiv=\"refresh\" content=\"2; url=20-14.php?id=".$id.'\">"; 
130 } 

131 else 

132 ( 

133 echo "修改 用 户 密码 失败 ， 现 在 返回 修改 用 户 记录 页 "; 

134 echo "<meta http-equiv=\"refresh\" content=\"2; url=20-15.php?id=".$id.\">"; 
135 ) 

136 ) 

137 ) 

138 ) 

139 ) 

140 ?» 


单 击 图 20.32 中 的 “修改 密码 ” 超 链接 ， 就 可 以 执行 该 文件 ， 执 行 结果 如 图 20.33 所 示 。 


EEC 一 一 

[€] EE | exu 
修改 用 产 admin 的 密码 

论坛 首页 量 示 信息 | 修改 信息 
DABS: [| 
输入 新 密码: | 1] 
再 输入 一 次 ， | 
ax 


Rox ~ 


图 20.33 ”用户 修改 密码 执行 结果 
依次 输入 用 户 的 旧 密 码 、 新 密码 、 重 复 新 密码 ， 然 后 单 击 “ 提 交 ” 按 钮 就 可 以 把 输入 内 容 提 交 到 
后 台 进 行 处 理 。 
如 果 用 户 输入 正确 ， 并 且 执 行 了 相关 操作 ， 则 用 户 的 旧 密码 就 会 被 新 密码 蔡 代 ， 以 完成 修改 密码 
的 操作 。 
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208.4 用 户 退 出 页 面 


EE 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 20 章 \ 用 户 退 出 页 面 .wmv 

通常 情况 下 ,还 应 该 设计 一 个 用 户 退出 登录 的 页 面 ， 以 方便 用 户 随时 退出 系统 。 为 了 使 主 程序 
能 够 访问 该 页 面 ， 应 该 对 论坛 首页 文件 进行 修改 ， 以 加 入 该 页 的 链接 。 

在 20-5.php 中 找到 以 下 内 容 : 


echo "<td>"; 
ifS COOKIE[user]) /如果 没 有 用 户 登录 ， 显 示 登 录 链 接 
{ 
echo "<a href=\"20-4.php\"> 用 户 登 录 </a>"; 
else // 如 果 用 户 已 经 登录 ， 显 示 登 录用 户 名 
{ 


require "20-1.php"; 

$sql-"select id from $table members where name-'$ COOKIE[user]"'; 
S$resultzmysql query($sql.Slink); 

$rows-mysql fetch array(Sresult); 

echo "登录 用 户 : «a href-20-14.php?id-" $rows[0]."»".$ COOKIE[user]."«/a»"; 


} 
echo "</td>\n"; 
将 其 修改 为 : 
echo "<td>"; 
if!$ COOKIE[user]) // 如 果 没有 用 户 登 录 ， 显 示 登 录 链接 
( 
echo "<a href=\"20-4.php\"> 用 户 登录 </a>"; 
else // 如 果 用 户 已 经 登录 ， 显 示 登 录用 户 名 
ii 
require "20-1.php"; 
S$sql-"select id from $table members where name-'$ COOKIE[user]"'; 
Sresultzmysql query(S$sql,Slink); 
S$rows-mysql fetch array($result); 
echo "登录 用 户 : «a href-20-14.php?id-" $rows[0].'»".$. COOKIE[user]." «/a»|"; 
echo "<a href=20-17.php> 退 出 登录 </a>"; 
J 
echo "</td>\n"; 


经 过 这 样 的 修改 就 为 主页 面 加 入 了 用 户 退 出 的 链接 。 
技巧 : 用 户 的 退出 操作 极其 简单 一 清空 用 户 注册 的 Cookie 记 录 然 后 再 跳 转 到 指定 页 即 可 。 
【实例 20-17】 以 下 为 用 户 退 出 页 面 的 代码 。 


re 实例 20-17: 用 户 退 出 页 面 
x 源码 路 径 : 光盘 \ 源 文件 20\20-17.php 
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01 <?php 

02 setcookie("user",""); 

03 echo "<html>"; 

04 echo "<head>"; 

05 echo "<title> 登 录用 户 安全 退出 </title>"; 

06 echo "<meta http-equiv=\"refresh\" content=\"2; url=20-5.php\">"; 
07 echo "</head>"; 

08 echo "<body>"; 

09 echo "<LINK href=\"style.css\" rel-stylesheet»"; 
10 echo "<center>"; 

11 echo "<h2> 登 录用 户 已 经 退出 </h2>"; 

12 echo "<h3> 两 秒 后 返回 论坛 首页 </h3>"; 

13 echo "</center>"; 

14 echo "</body>"; 

15 echo "«/html»"; 

16 ?> 


当 登 录用 户 单 击 “退出 登录 ”链接 后 ， 用 户 就 能 安全 地 从 系统 退出 。 
至 此 ， 用 户 管理 工作 基本 上 完整 了 。 不 但 能 够 显示 用 户 信息 ， 而 且 能 够 更 改 用 户 信息 ， 可 以 满足 
一 般 的 要 求 。 


20.9 ”进一步 完善 


GE 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 20 章 \ 进 一 步 完善 .wmv 

现在 ， 论 坛 程序 已 经 基本 上 能 够 满足 大 部 分 需求 ， 但 与 通常 的 论坛 相 比 还 存在 很 多 不 足 ， 大 致 有 
以 下 几 个 方面 : 

ED ”不 具有 文件 上 传 功能 。 通 常 的 论坛 都 会 在 用 户 发 表 新 主题 或 者 回复 时 有 一 个 文件 上 传 界面 允 
许 用 户 上 传 指定 类 型 及 限制 大 小 的 文件 。 这 个 功能 也 很 容易 实现 ， 关 于 如 何 上 传 文件 请 参看 
第 8 章 的 内 容 ， 这 里 只 给 出 思路 。 当 用 户 上 传 文件 后 ， 在 提交 用 户 发 表 主 题 或 回复 的 内 容 最 
后 加 上 指向 文件 下 载 页 面 的 链接 ， 而 专门 的 文件 下 载 页 面 则 指向 该 上 传 的 文件 。 这 样 就 可 以 
显示 指定 文件 ， 并 使 用 户 可 以 下 载 该 文件 了 。 
用 户 与 用 户 之 间 不 能 传送 信息 。 通 常 的 论坛 还 会 有 一 个 信息 系统 ， 即 不 同 的 用 户 之 间 可 以 互 
相 发 送信 息 ， 只 有 接收 人 才能 够 查看 。 这 样 当 用 户 登 录 论 坛 时 ， 如 果 有 未 读 的 新 信息 ， 则 系 
统 会 提示 用 户 进行 阅读 。 这 是 一 个 相当 有 用 的 功能 ， 实 现 起 来 并 不 复杂 ， 只 需要 在 原 有 的 表 
结构 上 再 加 一 个 信息 表 (MSN) 即 可 。 表 一 共有 这 样 几 个 字段 : ID、 发 件 人 、 收 件 人 、 内 容 、 
是 否 显示 、 是 否 阅读 等 。 然 后 为 收 、 发 信息 建立 专门 的 页 面 。 任 何 用 户 都 只 能 查看 收 件 人 为 
自己 名 字 的 信息 ,也 可 以 给 其 他 人 发 送信 息 。 信 息 的 阅读 初始 状态 为 False， 当 用 户 登录 论坛 ， 
系统 首先 检查 是 否 有 收 件 人 为 用 户 名 , 阅读 状态 为 False 的 信息 , 如 果 有 就 提醒 用 户 进行 阅读 。 
信息 在 用 户 阅读 后 ， 阅 读 状态 就 为 True。 用 户 也 可 以 选择 删除 自己 收 件 箱 中 的 信息 ， 而 实际 
上 的 删除 操作 只 是 把 显示 状态 改 为 False， 这 样 就 不 再 显示 该 信息 。 这 里 只 给 出 了 实现 机 制 ， 
有 兴趣 的 读者 可 以 自行 研究 以 实现 该 功能 。 
ED ”没有 为 用 户 定义 级 别 ， 普 通用 户 无 法 体会 到 升级 的 乐趣 。 通 常 的 论坛 都 会 为 用 户 根据 发 帖 数 
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量 或 者 积分 设 定 级 别 ， 如 0 一 50 为 初级 用 户 、50 一 100 为 中 级 用 户 、100 一 200 为 高 级 用 户 、 
200 一 500 为 超级 用 户 、500 一 1000 为 帝王 等 ， 这 样 可 以 促使 用 户 不 断 发 帖 以 提高 自己 的 级 别 。 
要 实现 这 样 的 功能 有 多 种 方法 。 一 种 就 是 把 相应 的 级 别 直 接 写 入 用 户 表 中 的 某 个 字段 ， 如 
LEVEL。 在 用 户 发 过 帖 时 判断 其 发 帖 数 属于 哪 一 个 级 别 ， 再 把 相应 级 别 写 入 该 字段 。 这 样 随 
着 发 帖 数 的 增加 ， 用 户 的 级 别 就 会 不 断 增 加 。 但 这 样 存在 一 个 次 端 ， 就 是 当 用 户 级 别 固 定 后 ， 
想 再 更 改 就 相当 困难 。 如 以 前 的 级 别 这 样 定义 初级、 中 级 、 高 级 、 超 级 ……， 现 在 想 把 用 
户 级 别 表示 方式 改 为 学 前 班 、 小 学 生 、 初 中 生 、 高 中 生 、 学 士 、 硕 士 、 博 士 等 。 如 果 逐 条 进 
行 修改 就 会 相当 困难 ， 而 且 在 实际 中 根本 是 不 可 能 的 。 所 以 可 以 不 设 定 用 户 的 级 别 字段 ， 当 
在 需要 显示 用 户 级 别 时 ， 读 取 用 户 的 发 帖 数 与 特定 配置 文件 中 的 分 数 段 表示 值 进行 比较 。 用 
户 属于 哪个 范围 ， 就 显示 相应 的 级 别 。 如 现在 有 配置 文件 ， 定 义 0 一 50 为 初级 用 户 、50 一 100 
为 中 级 用 户 、100 一 200 为 高 级 用 户 、200 一 500 为 超级 用 户 、500 一 1000 为 帝王 。 显 示 时 把 用 
户 发 帖 数 与 这 些 配置 进行 比较 ， 属 于 哪个 范围 ， 显 示 相应 的 级 别 即 可 ， 而 想 更 改 级 别 表 示 方 
法 时 只 需要 更 改 配置 文件 即 可 ， 这 样 可 以 保证 级 别 表示 方法 的 可 移植 性 。 限 于 篇 幅 也 不 再 给 
出 具体 代码 ， 有 兴趣 的 读者 可 以 去 尝试 。 

只 有 一 个 超级 管理 员 ， 各 个 分 论坛 没有 相应 的 版 主 。 如 果 需 要 版 主 ， 就 要 给 每 个 论坛 的 分 类 
都 增加 一 个 字段 用 于 存放 版 主 的 ID， 再 把 相应 用 户 的 admin 值 改 为 1 以 区 别 于 普通 用 户 。 然 
后 再 给 这 些 版 主 赋予 相应 权限 即 可 。 

对 用 户 的 输入 没有 过 滤 功 能 。 用 户 的 恶意 输入 会 对 论坛 造成 破坏 ， 所 以 应 该 屏蔽 用 户 的 输入 ， 
以 处 理 掉 HTML 标记 。 这 里 只 需要 使 用 htmlspecialchars() 函 数 对 用 户 输入 进行 处 理 即 可 ， 这 
里 不 再 袭 述 。 

其 他 更 为 高 级 的 功能 。 一 个 完整 的 论坛 还 有 更 多 的 功能 ， 如 常见 的 在 线 用 户 列表 、 用 户 生 日 
友情 提示 、 版 主 可 以 奖励 用 户 积分 、 置 项 帖 、 精 华 帖 等 。 可 以 这 样 说 ， 要 想 讲 清楚 论坛 的 所 
有 功能 都 需要 一 本 书 。 由 于 本 书 的 篇 幅 所 限 ， 只 能 讲 些 最 基本 的 功能 ， 更 多 的 功能 都 有 待 读 
者 在 以 后 的 学 习 中 进一步 完成 。 


20.10 A € 小结 


本 章 向 读者 介绍 了 如 何 用 所 学 的 PHP 知识 来 实现 一 个 简单 的 论坛 。 本 章 把 一 个 论坛 分 解 为 表 的 设 
计 、 数 据 库 表 的 创建 、 用 户 的 注册 与 登录 、 论 坛 的 显示 、 主 题 的 发 表 与 回复 、 论 坛 分 类 的 管理 、 帖 子 
的 管理 、 用 户 的 管理 儿 大 项 分 别 进行 了 说 明 。 通 过 本 章 的 学 习 , 用 户 不 仅 进一步 深化 了 PHP 对 MySQL 
数据 库 的 操作 ， 而 且 对 于 如 何 通过 PHP 代码 、 算 法 来 解决 实际 问题 都 有 了 一 个 深刻 的 认识 。 


tels 网 上 商城 全 站 系统 


本 章 结合 前 面 所 学 的 内 容 来 制作 一 个 网 上 商城 系统 。 本 章 将 向 读者 介绍 如 何 使 用 PHP 和 MySQL 
数据 库 来 实现 一 个 网 上 商城 全 站 程序 。 通 过 本 章 的 学 习 ， 相 信 读 者 会 对 PHP 及 MySQL 数据 库 的 知识 
有 一 个 全 新 的 认识 。 


21.1 系统 分 析 


G 知识 点 讲解 : 光 瘟 \ 视 频 讲解 \ 第 21 章 \ 系 统 分 析 .wmv 
在 制作 系统 之 前 ， 首 先 需 要 分 析 系统 所 要 实现 的 功能 ， 以 明确 制作 目的 。 只 有 目的 明确 才能 有 的 
放 矢 ， 使 接 下 来 的 工作 事半功倍 。 作 为 一 个 网 上 商城 ， 面 对 的 是 用 户 ， 所 以 必 不 可 少 的 是 要 有 一 个 用 
户 注册 与 登录 系统 ， 这 是 构建 用 户 系统 的 前 提 。 用 户 可 分 为 管理 员 与 普通 用 户 两 类 。 
1. 管理 员 
管理 员 在 登录 系统 后 ， 可 以 在 后 台 对 图 书记 录 表 进行 增加 和 删除 操作 ， 也 可 以 在 后 台 修 改 图 书 的 
类 别 ， 查 看 、 回 复 用 户 的 购书 订单 。 
2. 普通 用 户 
普通 用 户 登 录 系统 后 ， 则 能 进行 浏览 、 搜 索 图 书 等 操作 。 浏 览 图 书 可 以 给 予 用 户 一 定 的 自由 ， 如 
按 种 类 浏览 或 者 按 添加 时 间 浏 览 等 。 搜 索 图 书 也 有 一 定 的 自由 性 ， 用 户 可 以 把 图 书 的 名 称 、 作 者 、 出 
版 社 、 所 属 的 类 别 或 者 价格 等 作为 条 件 对 图 书 进行 搜索 。 
注意 : 普通 用 户 也 可 以 查看 图 书 详细 情况 ， 并 把 图 书 加 入 购物 车 。 添 加 到 购物 车 后 ， 用 户 就 可 以 随时 
查看 购物 车 内 容 以 及 更 改 购物 车 。 例 如 ， 可 以 更 改 购物 车 中 某 一 类 商品 的 数量 ， 或 删除 某 一 类 
商品 。 在 确定 了 所 购 图 书后 ， 在 前 台 提交 购物 车 ， 给 商城 下 订单 。 


21.2 设计 数据 库 表 结构 
数据 表 设 计 的 成 功 与 和 否 直接 影响 到 程序 的 执行 效率 。 本 节 完 成 数据 库 表 结构 的 设计 。 在 整个 系统 


中 ， 要 实现 系统 分 析 所 要 求 的 功能 ， 共 需要 建立 5 个 表 : 用 户 表 、 图 书 类 型 表 、 图 书记 录 表 、 订 单 记 
录 表 和 销售 记录 表 。 
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21.2.1 用 户 表 的 设计 


GE 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 21 章 \ 用 户 表 的 设计 .wmv 
用 户 表 主 要 存放 注册 用 户 的 信息 。 该 表 主 要 包括 索引 ID、 用 户 名 、 用 户 密码 、 用 户 图 像 、 用 户 的 
地 址 、 电 子 信箱 、QQ 号 码 、MSN 地 址 、 注 册 时 间 、 购 物 数量 等 基本 信息 ， 其 中 还 应 有 一 字段 以 判断 
用 户 身份 ， 如 果 该 字段 值 为 0， 则 为 普通 用 户 ;为 1， 则 为 管理 员 。 该 表 具体 字段 如 表 21.1 所 示 。 
R211 用 户 表 user 


字 段 名 数据 类 型 是 否 允许 为 空 说 AA 
id int(5) 5 索引 ID (主键 、 自 动 增 1) 
name, varchar( 12 f HP 

password varchar(40) 否 用 户 密码 

photo varchar(80) f 用 户 图 像 

address varchar(80) 否 用 户 的 地 址 

email varchar(80) F 电子 信箱 

q varchar(15 是 QQ 号码 

msn varchar(80) 是 MSN 地 址 

reg date varchar(20) 否 注册 时 间 

post num int(5 f 购物 数量 

admin int(1 f 用 户 身份 判断 


注意 : 注意 各 个 字段 是 否 为 空 选项 。 


21.22. 图书 类 型 表 的 设计 


CÈ 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 21 章 \ 图 书 类 型 表 的 设计 .wmv 

图 书 类 型 表 存放 图 书 的 类 别 ， 图 书 的 类 别 有 二 级 分 类 ， 如 主 类 别 为 计算 机 类 用 书 ， 二 级 类 别 可 以 
为 硬件 类 、 软 件 类 、 网 络 类 、 电 子 娱乐 类 等 。 要 实现 这 样 的 分 类 ， 必 须 有 图 书 类 别 表 来 存放 。 该 表 应 
该 包含 的 基本 信息 有 索引 ID、 主 类 别 ID、 类 别名 称 、 类 别 描述 、 类 别 数量 等 。 该 表 具 体 字段 如 表 212 
所 示 。 


表 21.2 类 型 表 type 
BERAE t AA 
否 索引 ID (主键 、 自 动 增 1) 


p id 否 子 类 别 所 属 主 类 别 ID 

type name varchar(12) E 类 别名 称 

type description varchar(80) E 类 别 描述 

type num int(5) "u 本 类 别 的 帖子 数 ， 当 发 本 类 帖 时 ， 该 值 增加 Y 
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21.2.3 ”图书 记录 表 的 设计 
FH 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 21 章 \ 图 书记 录 表 的 设计 .wmv 


图 书记 录 表 存 入 图 书 的 所 有 主要 信息 ， 大 致 内 容 有 索引 ID、 书 名 、 作 者 、 出 版 社 、 所 属 子 分 类 、 

价格 、 内 容 简介 、 封 面 扫描 图 、 已 售 出 量 、 存 货 量 等 。 该 表 具 体 字 段 如 表 21.3 所 示 。 
表 21.3 图 书记 录 表 book 
字 段 名 数据 类 型 是 否 允 许 为 空 说 了 明 

id int(5 否 索引 ID (主键 、 自 动 增 1) 

book name varchar(40) 否 图 书 的 名 称 

book author varchar(20) F 图 书 的 作者 

book pub varchar(40) F 图 书 的 出 版 社 

book type int(5) f 图 书 所 属 类 别 

book cost varchar(6 ) f 图 书 售 价 

book description varchar(200 f 图 书 描述 

book photo varchar(80 f 图 书 封面 扫描 图 

book sale num int(5 否 图 书 售 出 量 

book num int(5) f 图 书 存货 量 
21.24 订单 记录 表 的 设计 


多 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 21 章 \ 订 单 记录 表 的 设计 .wmv 
用 户 在 选择 了 相应 商品 并 提交 后 ， 提 交 的 记录 将 以 订单 的 形式 保存 在 订单 记录 表 中 。 只 有 当 管 理 


者 回复 了 这 些 订单 ， 并 且 完 成 了 交易 ， 相 应 的 订单 才 会 变 成 真正 的 销售 记录 。 一 个 订单 表 内 容 应 该 包 


括 索引 ID、 提 交 者 ID、 提 交 者 用 户 名 、 所 购 图 书信 息 《〈 包 括 所 购 图 书 ID、 数 量 ) 、 订 单 总 额 (为 此 
次 所 有 购书 的 总 额 ) 、 回 复 状 态 〈 用 户 提 交 后 ， 初 始 状态 为 False， 当 管理 员 回复 该 订单 后 ， 状 态 变 为 


True) 、 提 交 时 间 《〈 用 户 提交 订单 的 时 间 ) 等 。 该 表 具 体 字段 如 表 21.4 所 示 。 


表 21.4 订单 记录 表 order 
字 段 名 数据 类 型 是 否 人 允许 为 空 说 AA 

id int(5 5 索引 ID (主键 、 自 动 增 1) 
order user id int(5) 5 提交 者 名 称 

order user name varchar(20) 5 提交 者 ID 

order book id int(5) 否 HWRE ID 
order_book_num int(5) "5 购书 数量 

order content varchar(80) E 订单 内 容 

order cost varchar( 10) E 订购 价格 

order state enum('true','false" 否 /默认 值 为 false 订单 状态 

order date varchar(40) K 订购 时 间 
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21.2.5 ”销售 记录 表 的 设计 


FH 知 识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 21 章 \ 销 售 记录 表 的 设计 .wmv 


销售 记录 表 是 直接 由 订单 记录 表 变 化 而 来 的 ， 用 户 提交 的 订单 经 管理 员 回复 后 就 变 成 实 实在 在 的 
销售 记录 。 所 以 ， 该 表 内 容 与 订单 记录 表 基 本 类 似 ， 只 不 过 多 一 个 回复 时 间 字 段 。 该 表 具 体 字段 如 


表 21.5 所 示 。 
表 21.5 销售 记录 表 sale 
字 段 名 数据 类 型 是 否 允许 为 空 说 — m 
id int(5) f 索引 ID 〈 主 键 、 自 动 增 1) 
order user id int(5) 5 提交 者 名 称 
order user name varchar(20) 否 提交 者 ID 
order book id int(5) 5 所 购 图 书 ID 
order book num int(5) E 购书 数量 
order content varchar(80) 否 订单 内 容 
order cost varchar(10) 否 订购 价格 
order state enum('true','false' 否 /默认 值 为 false | 订单 状态 
order date varchar(40) E 订购 时 间 
sale order id int(5. 否 对 应 订单 ID 
sale date varchar(40) f 销售 时 间 〈 即 管理 员 回 复 时 间 》 


至 此 ， 该 系统 所 需要 的 5 个 表 全 部 设计 完毕 。 从 21.3 节 开始 将 通过 具体 的 代码 来 实现 网 上 商城 全 
站 系统 的 所 有 功能 。 


21.3 准备 工作 

在 开始 实现 网 上 商城 全 站 系统 的 所 有 功能 之 前 ， 要 做 一 些 必要 的 准备 工作 。 其 中 一 项 就 是 建立 配 
置 文件 ， 以 便 在 后 面 程序 中 调用 ， 另 一 项 是 创建 系统 运行 所 需要 的 各 种 表 ， 即 进行 系统 的 安装 。 本 节 
就 来 具体 实现 这 些 工 作 。 


配置 文件 的 创建 


GER 知识 点 讲解 : 光盘 \ 视 频 讲 解 \ 第 21 章 \ 配 置 文件 的 创建 .wmv 

和 前 面 儿童 所 讲 到 的 与 数据 库 相 关 的 程序 一 样 ， 程 序 所 访问 的 主机 名 、 连 接 主 机 的 用 户 名 、 用 户 
密码 及 数据 库 名 通常 都 是 固定 不 变 的 。 各 种 表 名 ， 在 创建 后 也 是 不 变 的 。 所 以 应 该 把 这 些 重要 的 变量 
单独 拿 出 做 成 配置 文件 ， 以 便于 其 他 程序 文件 来 调用 。 在 配置 文件 中 存放 着 程序 运行 所 需要 的 数据 库 
的 主机 名 、 连 接 主机 的 用 户 名 、 用 户 密码 、 数 据 库 名 、 表 名 等 信息 。 

【实例 21-1】 以 下 为 网 上 商城 系统 的 配置 文件 。 


实例 21-1: 配置 文件 
源码 路 径 : 光盘 \ 源 文件 21\21-1.php 


21.3.1 
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01 <?php 

02 $db_host="localhost"; /主机 名 

03 $db user-"root"; /用 户 名 

04 $db pass-"admin"; IIFa Pi 
05 $db name-"test"; /数据 库 名 
06 $table user-"user"; IAPR 

07 $table_type="type"; /图 书 类 型 表 
08 $table book-"book"; // 图 书记 录 表 
09 $table order-"order"; // 订 单 记 录 表 
10 $table sale-"sale"; [E 
11 $linkzmysql connect($db host,$db user,$db pass); Isi E 
12 mysql select db($db name,$link); /选择 数据 库 
13 ?> 


注意 : 以 上 配置 信息 可 以 根据 实际 情况 进行 修改 。 
21.3.2 ”安装 文件 的 创建 


多 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 21 章 \ 安 装 文件 的 创建 .wmv 

创建 程序 运行 所 需要 的 各 种 表 是 程序 运行 的 前 提 ， 本 节 就 来 实现 表 的 创建 。 以 下 代码 实现 的 功能 
是 先 让 用 户 输入 各 种 内 容 ， 包 括 注册 的 管理 员 信息 、 表 的 前 绥 等 信息 。 然 后 在 后 台 获 取 用 户 提交 内 容 ， 
创建 各 种 表 ， 并 为 用 户 表 插 入 管理 员 的 信息 。 

【实例 21-2】 以 下 为 安装 文件 的 代码 。 


实例 21-2. 安装 文件 
源码 路 径 : 光盘 \ 源 文件 21\21-2.php 


01 <?php 

02 error reporting(0); 

03 echo "«html»"; 

04 echo "<head>"; 

05 echo "«title» Z2 3€ f FF </title>"; 

06 echo "</head>"; 

07 echo "<body>"; 

08 echo "<LINK href=\"style.css\" rel-stylesheet»"; 
09 i$ POST['admin']) /如 果 没 有 默认 参数 ， 显 示 HTML 
10 { 

11 echo "<script language=\"javascript\">"; 
12 echo "function juge(theForm)"; 

13 echo "(*; 

14 echo "if (theForm.admin.value == V") 
15 echo "(*; 

16 echo "alert(\" 请 输入 管理 员 名 称 ! \");"; 
17 echo "theForm.admin.focus();"; 

18 echo "return (false);"; 

19 echo "}"; 

20 echo "if (theForm.pass.value == VY)"; 
21 echo "(*; 

22 echo "alert(\" 请 输入 管理 员 密 码 !\");"; 
23 echo "theForm.pass.focus();"; 
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echo "return (false);"; 

echo "}"; 

echo "if (theForm.pass.value.length « 8 )"; 

echo "{"; 

echo "alert "密码 至 少 要 8 位 ! V); 

echo "theForm.pass.focus();"; 

echo "return (false);"; 

echo "5 

echo "if (theForm.re pass.value !-theForm.pass.value)"; 

echo "(*; 

echo "alert(\" 确 认 密 码 与 密码 不 一 致 ! V" 

echo "theForm.re pass.focus();"; 

echo "retum (false);"; 

echo "}"; 

echo "if (theForm.pre.value == V") 

echo "(* 

echo "alert(\" 请 输入 表 前 缀 ! V)"; 

echo "theForm.pre.focus();"; 

echo "return (false);"; 

echo "^ 

echo "j^ 

echo "function s photo(the)"; 

echo "(* 

echo "document.img.src-'images/"the.photo.value-*' .bmp*"; 
echo "}"; 

echo "«/script»"; 

echo "<center>"; 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">"; 
echo "<form method=\"post\" action=\"$PATH_INFO\" onsubmit=\"return juge(this)\">"; 
echo "<tr>"; 

echo "<td colspan=\"2\" align=\"center\"><font size=\"5px\"> 安 装 程序 </font></td>"; 
echo "</tr>"; 

echo "<tr>"; 

echo "<td> 管 理 员 : 〈 后 台 登 录 ) </td>"; 

echo "<td><input type=\"text\" name=\"admin\"></td>"; 

echo "</tr>"; 

echo "<tr>"; 

echo "<td> 管 理 员 密码 : 〈 不 小 于 8 位 ) </td>"; 

echo "<td><input type=\"password\" name=\"pass\" size=\"21\"></td>"; 
echo "</tr>"; 

echo "<tr>"; 

echo "<td> iA E3: </td>"; 

echo "<td><input type=\"password\" name=\"re_pass\" size=\"21\"></td>"; 
echo "</tr>"; 

echo "<tr>"; 

echo "<td> 管 理 员 E-mail: (AE) </td>"; 

echo "<td><input type=\"text\" name=\"email\"></td>"; 

echo "</tr>"; 

echo "<tr>"; 

echo "<td> 选 择 图 像 : </td>"; 

echo "<td>"; 

echo "<select name=\"photo\" size=\"1\" onchange=\"s_photo(this.form)\">"; 
for($i=1;$i<21;$i++) 


{ 
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echo "<option value=". $i.">".$i."</option>";; 


} 
echo "</select>"; 


echo "<img src=\"images/1.bmp\" name=\"img\">"; 


echo"</td>"; 
echo "</tr>"; 
echo "<tr>"; 
echo "<td> 表 的 前 缀 : </td>"; 


echo "<td><input type=\"text\" name=\"pre\" value=\"book \"></td>"; 


echo "</tr>"; 
echo "<tr>"; 
echo "<td colspan=\"2\"><center>"; 


echo "<input type=\"submit\" value=\" 下 一 步 \">"; 


echo "<input type=\"reset\" value=\" 重 新 填 \">"; 
echo "</center></td>"; 

echo "</tr>"; 

echo "</form>"; 

echo "</table>"; 

echo "</center>"; 

echo "</body>"; 

echo "<html>"; 


$name-$ POST[admin]; 
$password-md5($ POST[pass7); 

$email-$ POST[email]; 

$photo-$ POST[photo]; 

$pre-$ POST[pre7; 

require "21-1.php"; 

$table user-Spre.$table user; 

$table type-S$pre.$table type; 

$table book-$pre.$table book; 

$table order-$pre.$table order; 

$table sale-Spre.Stable sale; 
$time-date("Y ££ m H d RH"); 

$sql-"create table $table user( 

id int(5) not null auto increment primary key, 
name varchar(12) not null, 

password varchar(40) not null, 

photo varchar(80) not null, 

address varchar(80) not null, 

email varchar(80) not null, 

qq varchar(15), 

msn varchar(80), 

reg date varchar(20) not null, 

post num int(5) not null default O, 

admin int(1) not null 

Y 

mysql_query($sql, $link) or die(mysql error()); 
$sql-"create table $table type( 

id int(5) not null auto increment primary key, 


/如 果 有 POST 参数 ， 执 行 操作 


// 获 得 参数 
// 获 得 密码 ， 并 使 用 MDS 进行 加 密 操 作 


// 发 送 创建 user 表 的 SQL 请 求 
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130 p. id int(5) not null, 

131 type name varchar(12) not null, 

132 type description varchar(80) not null, 

133 type num int(5) not null default O 

134 ha 

135 mysql query(Ssql,Slink) or die(mysql error()); /发 送 创建 type 表 的 SQL 请 求 
136 $sql="create table $table book( 

137 id int(5) not null auto increment primary key, 

138 book name varchar(40) not null, 

139 book author varchar(20) not null, 

140 book pub varchar(40) not null, 

141 book type int(5) not null, 

142 book cost varchar(6) not null, 

143 book description varchar(200) not null, 

144 book photo varchar(80) not null, 

145 book sale num int(5) not null, 

146 book num int(5) not null 

147 ya 

148 mysql query($sql,Slink) or die(mysql_error()); /发 送 创建 book 表 的 SQL 请 求 
149 $sql="create table $table order( 

150 id int(5) not null auto increment primary key, 

151 order user id int(5) not null, 

152 order user name varchar(12) not null, 

153 order book id int(5) not null, 

154 order book num int(5) not null, 

155 order content varchar(80) not null, 

156 order cost varchar(10) not null, 

157 order state enum('true','false') not null default 'false', 

158 order date varchar(40) not null 

159 y; 

160 mysql query($sql,Slink) or die(mysql error()); /发 送 创建 order 表 的 SQL 请 求 
161 $sql="create table $table sale( 

162 id int(5) not null auto increment primary key, 

163 sale order id int(5) not null, 

164 sale date varchar(40) not null 

165 y; 

166 mysql! query(Ssql,Slink) or die(mysql error()); /发 送 创建 sale 表 的 SQL 请 求 
167 $sql="insert into $table_type(p_id,type_name,type_description)values('0",' 主 类 别 1',' 系 统 创建 的 
RUEZ)"; 

168 mysql! query(Ssql,Slink) or die(mysql_error()); /发 送 添加 默认 主 分 类 的 SQL 请 求 
169 $sql="insert into $table type(p idtype name,type description)values('1', 4 368J 1',' 系 统 创建 的 
RUDRA)"; 

170 mysql_query($sql, $link) or die(mysql_error()); /发 送 添加 默认 子 分 类 的 SQL 请 求 
171 $sql-"insert into  $table user(name,password,photo,address,email,qq,msn,reg date,admin) 


values($name','$password',$photo',"'Semail',","'Stime','3')"; 


172 
173 
174 
175 
176 
177 


e. 


mysql query($sql,Slink) or die(mysql error()); /发 送 添加 管理 员 信息 的 SQL 请 求 
$fp=fopen("21-1.php" w+ // 将 更 新 过 的 数据 写 入 配置 文件 
fputs($fp,"<?php"); 

fputs($fp,"\$db_host=\"localhost\";"); 

fputs($fp,"\$db_user=\"root\";"); 

fputs($fp,"\$db_pass=\"admin\";"); 


178 
179 
180 
181 
182 
183 
184 
185 
186 
187 
188 
189 
190 
191 
192 
193 
194 
195 
196 
197 
198 
199 
200 
201 
202 
203 
204 
205 
206 
207 ?» 


) 


8018 manse 00000 


fputs($fp,"$db name-'testV';"); 

fputs(S$fp,$table user-V'$table usen"); 
fputs($fp," Stable type-V'Stable type"); 

fputs($fp, Stable book-V'Stable book";"); 

fputs($fp,$table order-V'$table order";"); 

fputs($fp, Stable sale-'$table saleV';"); 
fputs($fp,Slinkzmysql connect($db host|$db user|$db pass);"); 
fputs($fp,"mysql select db(\$db_name,\$link);"); 

fputs($fp,"?2"); 

fclose(Sfp); 

echo "<center>"; 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">"; 

echo "<tr>"; 

echo "<td align=\"center\"><font size=\"5px\"> 安 装 程序 </font></td>"; 
echo "</tr>"; 

echo "<tr>"; 

echo "<td align-V'centerV'» «font size=\"3px\"> 成 功 安装 ! </font></td>"; 
echo "</tr>"; 

echo "<tr>"; 

echo "<td align-V'centerV'» «font size=\"3px\"> 删 除 该 文件 ， 以 减少 潜在 危险 ! </font></td>"; 
echo "</tr>"; 

echo "<tr>"; 

echo "<td align=\"center\"> 点 <a href=\"21-5.php\"> 这 里 </a> 进 入 </td>"; 
echo "</tr>"; 

echo "</table>"; 

echo "</center>"; 

echo "</body>"; 

echo "</html>"; 


在 PHP 运行 环境 下 执行 该 文件 ， 完 成 整个 系统 运行 所 需要 的 各 种 表 的 创建 。 该 文件 执行 的 前 台 结 


果 如 图 21.1 所 示 。 


eI 
[€] Jd mmecneaci D - C | S zaer [R 
安装 程序 
ERA. (ERES) 
管理 员 帘 码 ， (不 小 于 8 位 ) ] 
确认 密码 : ] 
管 埋 员 E-mail。， (Ë) 
ime. [1 
EH rm 
| r-5 | sur 
R100% ~ 


图 21.1 首次 运行 安装 文件 的 执行 结果 


按照 要 求 填 入 全 部 信息 ， 填 写 完毕 后 单 击 “ 下 一 步 ” 按 钮 ， 将 出 现 如 图 21.2 所 示 的 执行 结果 。 


S) 


(000 PHP BIB RE 


Em 
安装 程序 
Dong SI 
WRH Dus ETE E! 
点 这 里 进入 
A100 ~ 


图 21.2 安装 完成 执行 结果 
成 功 执行 安装 后 ， 系 统 运行 所 需要 的 表 创建 完毕 。 
随 着 安装 程序 正确 执行 ， 系 统 实现 前 的 准备 工作 就 告 一 段落 。 从 21.3.3 小 节 开始 就 将 通过 具体 的 
代码 来 实现 所 需 的 各 项 功能 。 


21.3.3 ” 头 文件 的 创建 


多 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 21 章 \ 头 文件 的 创建 .wmv 

本 小 节 来 创建 一 个 头 文件 ， 它 可 以 方便 地 链接 到 其 他 页 面 。 在 其 他 文件 中 调用 该 文件 ， 一 方面 可 
以 减少 代码 量 ， 另 一 方面 也 可 以 使 各 页 面 样式 保持 一 致 。 

【实例 21-3】 以 下 代码 为 一 个 简单 的 头 文件 。 


01 <?php 

02 echo "<LINK href=\"style.css\" rel=stylesheet>"; 

03 echo "<center>"; 

04 echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\" align=\"center\" bgcolor- \"#000000\">"; 
05 echo "<tr>"; 

06 echo "<td bgcolor=\"#cccc99\"><center><a href=\"21-5.php\"> 商 城 首 页 </a></center></td>"; 
07 echo "<td bgcolor=\"#cccc99\"><center><a href=\"21-6.php\"> 所 有 图 书 </a></center></td>"; 
08 echo "<td bgcolor=\"#cccc99\"><center><a href=\"21-7.php\"> 分 类 查看 </a></center></td>"; 
09 echo "<td bgcolor=\"#cccc99\"><center><a href=\"21-6.php\"> 图 书 搜索 </a></center></td>"; 
10 echo "<td bgcolor=\"#cccc99\"><center><a href=\"21-8.php\"> 管 理 入 口 </a></center></td>"; 
11 echo "</tr>"; 

12 echo "</table>"; 

13 echo "<p>"; 

144 ?> 


说 明 : 由 于 该 文件 输出 内 容 都 是 最 普通 的 HTML 内 容 ， 所 以 不 过 多 解释 。 
214 用 户 的 注册 与 登录 
网 上 商城 也 需要 有 用 户 才 行 ， 用户 既是 各 类 商品 的 潜在 用 户 ， 也 是 商品 的 购买 者 。 所 以 ， 一 个 网 


e. 


21.4. 


01 


«?php 


s28 网 上 商城 全 站 系统 
上 商城 系统 必须 有 一 个 配套 的 用 户 注册 与 登录 系统 。 本 节 就 来 完成 用 户 的 注册 与 登录 功能 。 
1 ”用户 注册 


GE 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 21 章 \ 用 户 注册 -wmv 

用 户 注册 页 的 作用 是 给 出 一 个 用 户 界 面 ， 要 求 用 户 输入 新 的 用 户 名 及 其 他 相关 信息 ， 然 后 与 库 中 
所 保存 的 用 户 名 进行 比较 ， 如 果 用 户 名 已 经 存在 ， 则 给 出 出 错 提示 。 反 之 ， 就 将 用 户 的 输入 信息 作为 
一 条 新 的 记录 写 入 用 户 表 中 。 

【实例 21-4】 以 下 为 用 户 注册 页 面 实现 代码 。 


实例 21-4: 用 户 注册 页 面 
源码 路 径 : 光盘 \ 源 文件 21\21-4.php 


echo "<html>"; 

echo "<head>"; 

echo "<title> 注 册 新 用 户 </title>"; 

echo "</head>"; 

echo "<body>"; 

require "21-3.php"; 

if($ POST[user]) // 如 果 没 有 默认 参数 ， 


ü 


echo "<script language=\"javascript\">"; 
echo "function juge(theForm)"; 

echo "(* 

echo "if (theForm.user.value == VY)"; 
echo "(* 

echo "alert(\"' 请 输入 注册 用 户 名 ! Vy 
echo "theForm.user.focus();"; 

echo "return (false);"; 

echo "^ 

echo "if (theForm.pass.value == VY)"; 
echo "f"; 

echo "alert(\"' 请 输入 用 户 密码 ! Vy"; 

echo "theForm.pass.focus();"; 

echo "return (false);"; 

echo "i^; 

echo "if (theForm.pass.value.length < 8 )"; 
echo "(*; 

echo "alert(\" 密 码 至 少 要 8 fit! V)" 

echo "theForm.pass.focus();"; 

echo "return (false);"; 

echo "^ 

echo "if (theForm.re pass.value !-theForm.pass.value)"; 
echo "f"; 

echo "alert(\" 确 认 密 码 与 密码 不 一 致 ! \");"; 
echo "theForm.re pass.focus();"; 

echo "return (false);"; 

echo "}"; 


显示 HTML 
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37 echo "if (theForm.address.value == \"\")"; 

38 echo "(*; 

39 echo "alert(\" 请 输入 用 户 地 址 ! Vy" 

40 echo "theForm.address.focus();"; 

41 echo "return (false);"; 

42 echo "}"; 

43 echo "}"; 

44 echo "function s photo(the)"; 

45 echo "(* 

46 echo "document.img.src-'images/^the.photo.value-*' .bmp*"; 

47 echo "}"; 

48 echo "</script>"; 

49 echo "<center>"; 

50 echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">"; 

51 echo "<form method=\"post\" action=\"$PATH_INFO\" onsubmit=\"return juge(this)\">"; 
52 echo "«tr»"; 

53 echo "<td colspan=\"2\" align=\"center\"><font size=\"5px\"> 注 册 新 用 户 </font></td>"; 
54 echo "</tr>"; 

55 echo "<tr>"; 

56 echo "<td> 用 户 名 : (AAFF) </td>"; 

57 echo "<td><input type=\"text\" name=\"user\"></td>"; 

58 echo "</tr>"; 

59 echo "<tr>"; 

60 echo "<td> 用 户 密码 : 〈 不 小 于 8 位) </td>"; 

61 echo "<td><input type=\"password\" name=\"pass\" size=\"21\"></td>"; 
62 echo "</tr>"; 

63 echo "<tr>"; 

64 echo "<td> 确 认 密码 : </td>"; 

65 echo "<td><input type=\"password\" name=\"re_pass\" size=\"21\"></td>"; 
66 echo "</tr>"; 

67 echo "<tr>"; 

68 echo "<td> 用 户 E-mail: CR) </td>"; 

69 echo "<td><input type=\"text\" name=\"email\"></td>"; 

70 echo "</tr>"; 

Ti echo "<tr>"; 

72 echo "<td>QQ 5: (可 选 ) </td>"; 

73 echo "<td><input type=\"text\" name=\"qq\"></td>"; 

74 echo "</tr>"; 

75 echo "<tr>"; 

76 echo "<td>MSN S: 〈 可 选 ) </td>"; 

YAA echo "<td><input type=\"text\" name=\"msn\"></td>"; 

78 echo "</tr>"; 

79 echo "<tr>"; 

80 echo "<td> 选 择 图 像 : </td>"; 

81 echo "<td>"; 

82 echo "<select name=\"photo\" size=\"1\" onchange=\"s_photo(this.form)\">"; 
83 for($i=1;$i<21;$i++) 

84 { 

85 echo "<option value=".$i.">".$i."</option>";; 

86 ) 


87 echo "</select>"; 
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88 echo "<img src=\"images/1.bmp\" name=\"img\">"; 

89 echo"</td>"; 

90 echo "</tr>"; 

91 echo "<tr>"; 

92 echo "<td> 用 户 地 址 : </td>"; 

93 echo "<td><input type=\"text\" name=\"address\"></td>"; 
94 echo "</tr>"; 

95 echo "<tr>"; 

96 echo "<td colspan=\"2\"><center>"; 

97 echo "<input type=\"submit\" value=\" 下 一 步 \*>"; 

98 echo "<input type=\"reset\" value=\" 重 新 填 \">"; 

99 echo "</center></td>"; 

100 echo "</tr>"; 

101 echo "</form>"; 

102 echo "</table>"; 

103 echo "</center>"; 

104 echo "</body>"; 

105 echo "<html>"; 

106 } 

107 else 

108 ( 

109 S$user-$ POSTT[user]; 

110 $pass-md5($ POST[pass]); 

111 S$email-$ POST['email]; 

112 $msn-$ POST[msn]; 

113 $qq-$ POST ga; 

114 $photo-$ POST[photo'].".bmp"; 

115 $address-$ POST[address7; 

116 Stime-date("Y 4€ m A d A"); 

117 require "21-1.php"; 

118 $sql-"select id from $table user where name-'Suser"; 
119 S$resultzmysql guery($sal,$link) or die(mysql error()); 
120 $nums-mysql num rows(Sresult); 

121 if($nums!-0) 

122 { 

123 echo "<center>"; 

124 echo "<h2> 注 册 的 用 户 名 ".$user." 已 经 存在 ! </h2>"; 
125 echo "<h3> 请 点 <a href= onclick=history.go(-1)> 这 里 </a> 返 回 ， 重 新 输入 新 的 用 户 名 ! </h3>"; 
126 echo "</center>"; 

127 exit(); 

128 ) 

129 else 

130 fi 

131 $sql="insert into — Stable user(name,password,email,photo,msn,gg,address,reg date) 
values('Suser','$pass','Semail''S$photo','$msn','$qq', Saddress','$time")"; 
132 mysql query($sql.$link) or die(mysql error()); 
133 echo "<center>"; 

134 echo "<h2> 新 用 户 ".$user." 注 册 成 功 ! </h2>"; 
135 echo "<h3> 点 <a href=21-5.php> 这 里 </a> 进 行 登录 ! </h3>"; 
136 echo "</center>"; 

137 ) 


S 
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138 } 
139 ?> 


说 明 : 其 执行 过 程 相 对 简单 ， 这 里 不 再 演示 。 
2142 ”用 户 登 录 


FÈ 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 21 章 \ 用 户 登 录 .wmv 

用 户 注 册 后 ， 如 果 不 登录 系统 ， 还 是 和 匿名 用 户 没有 区 别 。 只 有 登录 了 系统 ， 才 能 拥有 普通 用 户 
所 没有 的 权限 ， 如 购买 图 书 等 。 用 户 登 录 的 道理 也 很 简单 ， 判 断 用 户 名 与 用 户 密码 ， 如 果 与 表 中 记录 
存在 相同 ， 则 把 用 户 名 和 ID 写 入 Cookie。 反 之 ,给 出 出 错 提示 ， 要 求 重新 输入 。 在 用 户 成 功 登 录 后 ， 
再 跳 转 到 指定 页 面 即 可 。 

【实例 21-5】 以 下 为 用 户 登录 页 面 实现 代码 。 


E wu [ww 


m... ms o] 源码 路 径 :光盘 \ 源 文件 21\21-5.php 

01 <?php 

02 if$ COOKIE[user]) 

03 { 

04 echo "<html>"; 

05 echo "<head>"; 

06 echo "<title> 注 册 用 户 已 经 登录 </title>"; 

07 echo "</head>"; 

08 echo "<body>"; 

09 require "21-3.php"; 

10 echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">"; 
11 echo "<tr>"; 

12 echo "<td colspan=\"2\" align=\"center\"><font size=\"5px\"> 注 册 用 户 管理 </font></td>"; 
13 echo "</tr>"; 

14 echo "<tr>"; 

15 echo "<td><a href=\"21-11.php\"> 修 改 用 户 信息 </a></td>"; 

16 echo "<td><a href=\"21-12.php\"> 修 改 用 户 密码 </a></td>"; 

17 echo "</tr>"; 

18 echo "<tr>"; 

19 echo "<td><a href=\"21-19.php\"> 查 看 我 的 购物 车 </a></td>"; 

20 echo "<td><a href=\"21-20.php\"> 查 看 我 的 历史 订单 </a></td>"; 
21 echo "</tr>"; 

22 echo "</table>"; 

23 echo "<br>"; 

24 require "21-1.php"; 

25 $sql-"select admin from $table user where id-'$ COOKIE[id]"'; 
26 S$resultzmysql query($sql.Slink); 

27 $rows-mysql fetch array(Sresult); 

28 if(Srows[0]-73) 

29 i 

30 echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">"; 
31 echo "<tr>"; 

32 echo "<td colspan=\"2\" align=\"centen\"><font size=\"5px\"> 商 品 管理 </font></td>"; 


) 


if$ POST[user]) 


i 
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echo "</tr>"; 
echo "<tr>"; 
echo "<td><a href=\"21-15.php\"> 增 加 新 的 类 别 </a></td>"; 
echo "<td><a href=\"21-16.php\"> 修 改 已 有 分 类 </a></td>"; 
echo "</tr>"; 
echo "<tr>"; 
echo "<td><a href=\"21-17.php\"> 增 加 新 的 商品 </a></td>"; 
echo "<td><a href=\"21-18.php\"> 修 改 已 有 商品 </a></td>"; 
echo "</tr>"; 
echo "<tr>"; 
echo "<td><a href=\"21-19.php\"> 查 看 订单 </a></td>"; 
echo "<td><a href=\"21-20.php\"> 销 售 记 录 </a></td>"; 
echo "</tr>"; 
echo "</table>"; 

h 

echo "</center>"; 

echo "</body>"; 

echo "«html»"; 

exit(); 


echo "«html»"; 

echo "<head>"; 

echo "<title> 注 册 用 户 登录 </title>"; 
echo "</head>"; 

echo "<body>"; 

require "21-3.php"; 

echo "<script languagez javascript"; 
echo "function juge(theForm)"; 

echo "(*; 

echo "if (theForm.user.value == \"\")"; 
echo "(* 

echo "alert iffi A FB P & ! Vy" 
echo "theForm.user.focus();"; 

echo "return (false);"; 

echo "}"; 

echo "if (theForm.pass.value == VY)"; 
echo "(* 

echo "alert( iB A FH PA Sz 3! Vy" 
echo "theForm.pass.focus();"; 

echo "return (false);"; 

echo "}"; 

echo "}"; 

echo "</script>"; 

echo "<center>"; 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">"; 


echo "<form method=\"post\" action=\"$PATH_INFO\" onsubmit=\"return juge(this)V"»"; 


echo "<tr>"; 


echo "<td colspan=\"2\" align=\"center\"><font size=\"5px\"> 注 册 用 户 登录 </font></td>"; 


echo "</tr>"; 
echo "<tr>"; 


// 如 果 没 有 默认 参数 ， 显 示 HTML. 


NK 
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85 echo "<td> 用 户 名 : </td>"; 

86 echo "<td><input type=\"text\" name=\"user\"></td>"; 
87 echo "</tr>"; 

88 echo "<tr>"; 

89 echo "<td> 用 户 密码 : </td>"; 

90 echo "<td><input type=\"password\" name=\"pass\" size=\"21\"></td>"; 
91 echo "</tr>"; 

92 echo "<tr>"; 

93 echo "<td> 选 择 COOKIE 有 效 期 : </td>"; 

94 echo "<td>"; 

95 echo "<select name=\"cook_t\" size=\"1\">"; 

96 echo "<option value=\"1\"> 最 短 时 效 </option>"; 

97 echo "<option value=\"2\">1 天 </option>"; 

98 echo "<option value=\"3\">1 月 </option>"; 

99 echo "<option value=\"4\">1 年 </option>"; 

100 echo "</select>"; 

101 echo"«/td»"; 

102 echo "</tr>"; 

103 echo "<tr>"; 

104 echo "<td colspan=\"2\"><center>"; 

105 echo "<input type=\"submit\" value=\" F —25V»"; 

106 echo "<input type=\"reset\" value=\" 重 新 填 \">"; 

107 echo "</center></td>"; 

108 echo "</tr>"; 

109 echo "</form>"; 

110 echo "</table>"; 

TH echo "</center>"; 

112 echo "</body>"; 

113 echo "<html>"; 

114 r 

115 else 

116 ^ 

117 Suser-$ POST[user]; 

118 $pass-md5($ POST[pass]); 

119 $cook t-$ POST['cook t]; 

120 require "21-1.php"; 

121 $sql-"select id from $table user where name-'Suser' and password-'$pass""; 
122 S$result-mysql query(S$sql,Slink) or die(mysql error()); 
123 $nums-mysql num rows(Sresult); 

124 if($nums==0) 

125 ( 

126 echo "<center>"; 

127 echo "<h2> 输 入 的 用 户 名 或 者 密码 错误 ! </h2>"; 
128 echo "<h3> 请 点 <a href=# onclick=history.go(-1)> 这 里 </a> 返 回 重新 输入 ! </h3>"; 
129 echo "</center>"; 

130 exit(); 

131 ) 

132 else 

133 t 

134 $rows-mysql fetch array($result); 

135 Sid-Srows[id"]; 


136 if($cook t--1) /根据 不 同 的 Cookie 设 定时 间 保 存 Cookie 
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137 ( 

138 setcookie("user", $user); 

139 setcookie("id",$id); 

140 } 

141 elseif($cook t==2) 

142 

143 setcookie("user", $user,time()+60*60*24); 
144 setcookie("id",$id,time()+60*60*24); 

145 } 

146 elseif($cook_t==3) 

147 

148 setcookie("user",Suser,time()*60*60*24*30); 
149 setcookie("id" Sid,time()*60*60*24*30); 
150 ji 

151 else 

152 f 

153 setcookie("user" Suser,time()*60*60*24*30*360); 
154 setcookie("id" Sid,time()*60*60*24*30*360); 
155 ) 

156 echo "«html»"; 

157 echo "<head>"; 

158 echo "<title> 注 册 用 户 登录 </title>"; 

159 echo "</head>"; 

160 echo "<body>"; 

161 require "21-3.php"; 

162 echo "<h2> 用 户 ".$user." 登 录 成 功 ! </h2>"; 

163 echo "<h3> 两 秒 后 进入 商城 首页 面 ! </h3>"; 

164 echo "<meta http-equiv=\"refresh\" content=\"2; url=21-6.php\">"; 
165 echo "</center>"; 

166 y 

167 

168 ?> 


说 明 : 由 于 用 户 登 录 过 程 也 比较 简单 ， 这 里 也 不 再 给 出 演示 。 如 果 要 浏览 相似 的 执行 结果 ， 请 查看 本 
书 第 20 章 相关 内 容 。 


215 前 台 显 示 界 面 
本 节 来 完成 系统 的 前 台 界 面 ， 即 普通 用 户 能够 看 到 的 界面 ， 其 中 包括 首页 面 、 图 书 列表 页 面 、 按 
种 类 查看 页 面 、 搜 索 图 书页 面 、 查 看 图 书 详情 页 面 等 。 


21.5.1 首页 面 的 实现 


GH 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 21 章 \ 首 页 面 的 实现 .wmv 
首页 面 是 用 户 进入 系统 后 看 到 的 第 一 个 页 面 ， 是 进入 其 他 页 面 的 前 提 。 本 节 来 完成 系统 首页 面 的 
设计 。 该 首页 面包 括 以 下 内 容 : 用户 登录 的 接口 、 总 图 书 数 、 注 册 用 户 人 数 、 图 书 的 分 类 查看 、 最 新 
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添加 的 图 书 、 图 书 的 搜索 界面 等 。 由 于 包括 内 容 比较 多 ， 所 以 首页 面 是 一 个 相对 复杂 的 页 面 。 
【实例 21-6】 以 下 为 首页 面 实 现代 码 。 


: 首页 面 


01 <?php 

02 echo "<html>"; 

03 echo "<head>"; 

04 echo "<title> 网 上 图 书 商城 首页 </title>"; 

05 echo "</head>"; 

06 echo "<body>"; 

07 echo "<center>"; 

08 require "21-3.php"; 

09 echo "<table width=80%>"; 

10 echo "<tr>"; 

11 echo "<td width=\"20%\">"; 

12 if(!$ COOKIE[user]) // 没 用 用 户 登录 ， 显 示 HTML 
13 T 

14 echo "<script language=\"javascript\">"; 
15 echo "function juge(theForm)"; 

16 echo "(*; 

17 echo "if (fheForm.user.value == \"\")"; 

18 echo "(*; 

19 echo "alert(" iB s A FH PA A& ! Vy 

20 echo "theForm.user.focus();"; 

21 echo "return (false);"; 

22 echo "}"; 

23 echo "if (IheForm.pass.value == Y)"; 

24 echo "(*; 

25 echo "alert(\" 请 输入 用 户 密码 ! Vy" 

26 echo "theForm.pass.focus();"; 

2 echo "return (false);"; 

28 echo "}"; 

29 echo "}"; 

30 echo "function juge2(theForm)"; 

31 echo "(*; 

32 echo "if (theForm.search c.value == \"\")"; 
33 echo "(*; 

34 echo "alert(\" 请 输入 搜索 内 容 ! Vy"; 

35 echo "theForm.search c.focus();"; 

36 echo "return (false);"; 

37 echo "}"; 

38 echo "}"; 

39 echo "</script>"; 

40 echo "<table cellpadding=\"1\" cellspacing=\"1\" width=\"100%\">"; 
41 echo "<form method=\"post\" action=21-5.php onsubmit=\"retum juge(this)\">"; 
42 echo "<tr>"; 

43 echo "<td><center> 用 户 登录 </center></td>"; 
44 echo "</tr>"; 
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echo "<tr>"; 

echo "<td> 用 户 名 :"; 

echo "<input type=\"text\" name=\"usen\" size=\"6\"></td>"; 
echo "</tr>"; 

echo "<tr>"; 

echo "<td> 密 &nbsp;&nbsp; 码 : "; 

echo "<input type=\"password\" name=\"pass\" size=\"5\"></td>"; 
echo "</tr>"; 

echo "<tr>"; 

echo "<td><center>"; 

echo "<input type=\"submit\" value=\" 登 录 \">"; 


echo "</center></td>"; 
echo "</tr>"; 
echo "</form>"; 
echo "</table>"; 
} 
else // 如 果 有 用 户 登录 ， 显 示 操作 链接 
{ 
echo "<table cellpadding=\"1\" cellspacing=\"1\" width=\"100%\">"; 
echo "<tr>"; 
echo "<td> 登 录用 户 : ".$_COOKIE['user]."</td>"; 
echo "</tr>"; 
echo "<tr>"; 
echo "<td><center><a href=\"21-15.php\"> 退 出 登录 </a></center></td>"; 
echo "</tr>"; 
echo "</table>"; 
} 
echo "<br>"; 
echo "<table cellpadding=\"1\" cellspacing=\"1\" width=\"100%\">"; 
echo "<tr>"; 
echo "<td><center> 本 站 信息 </center></td>"; 
echo "</tr>"; 
echo "<tr>"; 


echo "<td> 共 有 用 户 : "; 

require "21-1.php"; 

$sql-"select id from $table user"; 
S$result-mysql query($sql,Slink); 
$numzmysql num rows(S$result); 
echo $num; 

echo "4 </td>"; 

echo "</tr>"; 

echo "<tr>"; 

echo "<td> 共 有 图 书 : "S 
$sql="select id from $table book"; 
S$result-mysql query($sql,Slink); 
$num-mysql num rows(S$result); 
echo $num; 

echo "种 </td>"; 

echo "</tr>"; 

echo "</table>"; 

echo "<br>"; 
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C Srows2[type num.) "; 
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96 echo "<table cellpadding=\"1\" cellspacing=\"1\" width=\"100%\">"; 
97 echo "<tr>"; 

98 echo "<td> 最 新 用 户 : "; 

99 $sql="select name from $table user order by id desc"; 

100 S$result-mysql query($sql,Slink); 

101 $rows-mysql fetch array(S$result); 

102 echo $rows[O0]; 

103 echo "</td>"; 

104 echo "</tr>"; 

105 echo "<tr>"; 

106 echo "<td> 最 新 图 书 : "S 

107 $sql="select * from $table book order by id desc"; 

108 $result-mysql query($sql,Slink); 

109 $rows-mysql fetch array(S$result); 

110 echo "<a href-21-10.php?id-".$rows['id']."»".Srows[book name7."«/a»"; 
111 echo "</td>"; 

112 echo "</tr>"; 

113 echo "</table>"; 

114 echo "<br>"; 

115 echo "<table cellpadding=\"1\" cellspacing=\"1\" widthzV 10096"; 
116 echo "<tr>"; 

117 echo "<td> 图 书 分 类 :</td>"; 

118 echo "</tr>"; 

119 $sql2-"select * from $table type where p id!-0"; 

120 $result2=mysql_query($sql2,$link); 

121 while($rows2=mysql_fetch_array($result2)) 

122 { 

123 echo "<tr>"; 

124 echo "«td»"; 

125 echo "<a href=21-8.php?id=".$rows2[id].">".$rows2[type_name']."</a>: 
126 echo "«/td»"; 

127 echo "</tr>"; 

128 ) 

129 echo "</table>"; 

130 echo "«/td»"; 

131 echo "<td width=\"80%\">"; 

132 echo "<script language=\"javascript\">"; 

133 echo "function juge2(theForm)"; 

134 echo "f"; 

135 echo "if (theForm.search_c.value == \"\")"; 

136 echo "f"; 

137 echo "alert(\" 请 输入 搜索 内 容 ! \");"; 

138 echo "theForm.search c.focus();"; 

139 echo "return (false);"; 

140 echo "}'; 

141 echo "}'; 

142 echo "</script>"; 

143 echo "<table cellpadding=\"1\" cellspacing=\"1\" widthzV 10096" height=\"100%\">"; 
144 echo "<tr>"; 

145 echo "<form method=\"post\" action=\"21-9.php\" onsubmit=\"return juge2(this)\">"; 
146 echo "«td^18 RAE </td>"; 
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147 echo "<td> 搜 索 内 容 : "; 


148 echo "<input type=\"text\" name=\"search_c\" size=\"6\">"; 
149 echo "搜索 类 型 : " 

150 echo "<select name=\"search_t\" size=\"1\">"; 

151 echo "<option value=\"book_name\"> 书 名 </option>"; 


152 echo "<option value=\"book_author\W"> 作 者 </option>"; 
153 echo "<option value=\"book_pub\"> 出 版 社 </option>"; 
154 echo "</select>"; 

155 echo "<input type=\"submit\" value=\" 搜 索 \">"; 
156 echo "</td>"; 

157 echo "</form>"; 

158 echo "</tr>"; 

159 echo "</table>"; 

160 echo "<br>"; 

161 echo "<table cellpadding=\"1\" cellspacing=\"1\" width=\"100%\">"; 
162 if(Snum!-0) 

163 (echo "<tr>"; 

164 echo "<td colspan=\"2\"> 最 新 推荐 图 书 </td>"; 
165 echo "</tr>"; 

166 echo "<tr>"; 

167 echo "<td width=\"30%\"> 图 书 名 称 : </td>"; 
168 echo "«td»".$rows[book name7."«/td»"; 

169 echo "</tr>"; 

170 echo "<tr>"; 

171 echo "<td> 图 书 作 者 : </td>"; 

172 echo "<td>".$rows| book author')."</td>"; 

173 echo "</tr>"; 

174 echo "<tr>"; 

175 echo "<td> 出 版 社 : </td>"; 

176 echo "«td»".$rows[book pub']."«/td»"; 

177 echo "</tr>"; 

178 echo "<tr>"; 

179 echo "<td> 售 价 : </td>"; 

180 echo "<td>".$rows[book_cost]." 元 </td>"; 

181 echo "</tr>"; 

182 echo "<tr>"; 

183 echo "<td> 所 属 类 别 : «/td»"; 

184 echo "«td»".$rows[book type']."«/td»"; 

185 echo "</tr>"; 

186 echo "<tr>"; 

187 echo "<td> 该 书 的 数量 : </td>"; 

188 echo "<td>".$rows['book_num']."Æ </td>"; 

189 echo "</tr>"; 


190 echo "<tr>"; 

191 echo "<td> 该 书 的 简介 : </td>"; 

192 echo "«td»".$rows[book description." «/td»"; 
193 echo "</tr>"; 

194 echo "<tr>"; 

195 echo "<td> 该 书 的 封面 扫描 图 : </td>"; 

196 echo "<td>"; 

197 if(ISrows['book photo") 
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(0000 ea 


198 n 

199 $rows| book photo']-"images/nopic.gif"; 
200 ) 

201 echo "<img src-V".$rows[book photo'].""»": 


202 echo "</td>"; 
203 echo "</tr>"; 
204 echo "</table>"; 
205 echo "</td>"; 
206 echo "</tr>"; 


207 } 

208 else 

209 ( 

210 echo "<tr>"; 

211 echo "<td> 暂 时 没有 推荐 图 书 </td>"; 
212 echo "</tr>"; 

213 } 

214 echo "</table>"; 

215 echo "</center>"; 


216 echo "</body>"; 
217 echo "</html>"; 


218 ?> 


在 首页 面 用 管理 员 身 份 进行 登录 ， 首 页 将 会 出 现 如 图 21.3 所 示 的 执行 结果 。 


ie ae one or jons č =|| 


BE 所 有 图 书 AAEE pirs Ean 


Ame. 
admin 


YA 


Ba 
BRAA. 13 ^ 
书 AR. . [ T3 

saga o» SPEA HAAS PRAN. |$& vE] 


最 新 用 户 ， 暂时 没有 推荐 图 书 
admin 


最 新 图 书 ， 


图 书 分 类 : 
分 类 别 1， (0) 


Kiom - 


图 21.3 管理 员 登录 后 的 首页 执行 结果 
图 21.3 的 执行 结果 说 明 该 程序 正常 运行 。 
21.5.3 ”图 书 列表 页 面 的 实现 


EM 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 21 章 \ 图 书 列表 页 面 的 实现 .wmv 
图 书 列表 页 面 ， 按 照 添加 日 期 的 先后 ， 显 示 所 有 图 书 表 中 的 记录 ， 如 果 记 录 数 超过 了 每 页 显示 数 ， 
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则 分 页 显示 。 显 示 信 息 包括 书 名 、 作 者 、 价 格 、 类 别 、 简 介 〈 如 果 简 介 太 长 ， 则 截取 其 部 分 显示 ) o 
【实例 21-7】 以 下 为 图 书 列表 页 面 实现 代码 。 


01 


实例 21-7: 图 书 列表 页 面 
源码 路 径 : 光盘 \ 源 文件 21\21-7.php 


<?php 
echo "<html>"; 
echo "<head>"; 
echo "<title> 查 看 所 有 图 书 </title>"; 
echo "</head>"; 
echo "<body>"; 
echo "<center>"; 
require "21-3.php"; 
require "21-1.php"; 
echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">"; 


$sql="select id from $table book"; /从 列表 中 读 出 所 有 图 书记 录 
$result=mysql_query($sql,$link) or die(mysql_error()); /发 送 查找 列表 请 求 
$num=mysql_num_rows($result); /获取 结果 条 数 
$p. count-ceil($num/10); /| 总 页 数 
if($ GET[page']--0 && !$_GET[page']) $page=1; /| 当前 页 
else $page=$ GET[pageT; 
if($num«1) /如果 没有 记录 
{ 
echo "<tr>"; 
echo "<td>"; 
echo "<center><h2> 暂 时 还 没有 图 书 的 记录 </h2></center>"; /| 输出 相应 信息 
echo "</td>"; 
echo "</tr>"; 
exit(); // 退 出 所 有 PHP 代码 
) 
else // 如 果 有 记录 则 执行 相应 操作 
i 


$s-($page-1)*10; 
$sql-"select * from $table book order by id limit $s, 10"; 
S$result-mysql guery($sal,$link); 


echo "<tr>"; 
echo "<td> 书 名 </td>"; 
echo "<td> 作 者 </td>"; 
echo "<td> 价 格 </td>"; 
echo "<td> 类 别 </td>"; 
echo "<td> 简 介 </td>"; 
while($rows=mysql_fetch_array($result)) /| 循环 显示 记录 内 容 
{ 
echo "<tr>"; 
echo "<td><a href=\"21-10.php?id=". $rows[id]."\">".$rows[book_name'."</a></td>"; 
// 显 示 书 名 
echo "<td>".$rows[book_author]."</td>"; /显示 作者 
echo "<td>".$rows[book_cost]."</td>"; /显示 价格 


$sql2="select id,type_name from $table type where id='$rows[book_type]"; 
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44 $result2=mysql_query($sql2,$link); 

45 $rows2=mysql_fetch_array($result2); 

46 echo "<td><a href=\"21-8.php?id=".$rows2[0]."\">".$rows2[1]."</a></td>"; 
47 if(strlen($rows['book_description'])>100) 

48 $rows[book description']-substr($rows[description'],0, 100); 
49 echo "«td»".$rows[book description']."«/td»"; 

50 echo "</tr>"; 

51 ) 

52 H 

53 echo "</table>"; 

54 /以 下 为 分 页 显示 内 容 
55 $prev_page=$page-1; 

56 $next_page=$page+1; 

57 echo "<p align=\"centen">"; 

58 if ($page>1) 

59 

60 echo "<a href='$PATH_INFO?page=1'> 第 一 页 </a> | "; 

61 } 

62 if ($prev_page>=1) 

63 ^ 

64 echo "<a hrefz'$PATH INFO?page-$prev page'».E— J1«/a» |" 
65 ) 

66 if ($next page«-$p count) 

67 t 

68 echo "<a hrefz'$PATH INFO?page-$next page'» h— </a> |", 
69 ) 

70 if (S5page«$p count) 

71 ^ 

72 echo "<a href='$PATH_INFO?page=$p_count'> 最 后 一 页 </a></p>"; 
73 } 

74 echo "</center>"; 

75 echo "</body>"; 

76 echo "</html>"; 

i cd 


WEA: 该 PHP 执 行 机 理 相当 简单 ， 不 再 给 出 效果 图 。 


21.5.3 ” 按 种 类 查看 页 面 的 实现 
FR 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 21 章 \ 按 种 类 查看 页 面 .wmv 


按 种 类 查看 页 面 显示 图 书 的 所 有 种 类 ， 并 且 在 每 个 子 种 类 上 都 有 指向 该 种 类 查看 页 面 的 超 链接 ， 


用 户 只 需要 单 击 该 超 链接 ， 就 可 以 实现 查看 该 种 类 下 的 所 有 图 书 。 


这 里 把 所 有 种 类 的 显示 与 某 一 种 类 的 单独 显示 功能 整合 到 了 一 个 页 面 。 用 一 个 参数 来 判断 要 显示 
哪 一 类 。 如 果 没 有 任何 参数 ， 则 显示 所 有 种 类 。 如 果 指 定 了 参数 DD， 则 显示 某 一 类 的 结果 。 


【实例 21-8】 以 下 为 按 种 类 查看 页 面 实现 代码 。 


实例 21-8: 按 种 类 查看 页 面 
源码 路 径 : 光盘 \ 源 文件 21\21-8.php 
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01 <?php 

02 echo "<html>"; 

03 echo "<head>"; 

04 echo "<title> 按 种 类 查看 图 书 </title>"; 

05 echo "</head>"; 

06 echo "<body>"; 

07 echo "<center>"; 

08 require "21-3.php"; 

09 iflS GETI) 

10 { 

11 echo "<font size=5> 查 看 所 有 种 类 </font>"; 

12 echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">"; 

13 require "21-1.php"; 

14 $sql-"select * from $table type where p id-0"; 

15 $result-mysq! query($sql,Slink ; 

16 while($rows-mysq| fetch array(Sresult)) /| 循环 显示 主 类 别 
17 ( 

18 echo "<tr>"; 

19 echo "<td colspan=\"2\">"; 

20 echo $rows['type name']; 

21 echo " (".$rows['type num.) "; 

22 echo "</td>"; 

23 echo "</tr>"; 

24 $i-0; 

25 $sql2-"select * from Stable type where p id-'$rows[id] and id»'S$rows[id]"'; 
26 S$result22mysql! query($sql2.Slink) or die(mysql error()); 

27 $m count-mysql num rows(Sresult2); 

28 while($rows2-mysql fetch array(Sresult2)) ”// 循 环 显示 主 类 别 下 的 分 类 别 
29 { 

30 if($i%2==0) echo "<tr>"; 

31 echo "<td width=\"50%\">"; 

32 echo "<a href-21-8.php?id-" $rows2[id']."»".$rows2['type name7."«/a»"; 
33 echo " (".$rows2[type num].") "; 

34 echo "</td>"; 

35 $i++; 

36 if(($m_count%2==1) and $i==($m_count)) 

37 echo "«td»&nbsp;«/td»"; 

38 if($i%2==1) echo "</tr>"; 

39 f 

40 } 

41 ) 

42 else 

43 { 

44 require "21-1.php"; 

45 $sql-"select type name from $table type where id='$_GET[id]"; 

46 S$resultzmysq! query($sql.Slink); 

47 $type name-mysql fetch array(Sresult); 

48 echo "<font size=5> 查 看 种 类 : ".$type name[0]."«/font»"; 

49 echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">"; 

50 $sql="select * from $table book where book type-'$ GET[id] order by id desc"; 。 // 从 列表 中 
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读 出 所 有 图 书记 录 

51 $result=mysql_query($sql,$link) or die(mysql_error()); /发 送 查找 列表 请 求 

52 $num-mysql num rows(Sresult); /获取 结果 条 数 

53 $p count-ceil($num/10); /总 页 数 

54 if($ GET[page]--0 && !$_GET['page]) $page=1; /当前 页 

55 else $page-$ GET[page']; 

56 if($num«1) /如 果 没有 记录 

57 { 

58 echo "<tr>"; 

59 echo "«td»"; 

60 echo "<center><h2> 暂 时 还 没有 图 书 的 记录 </h2></center>"; ”// 输 出 相应 信息 

61 echo "</td>"; 

62 echo "</tr>"; 

63 exit(); 1/ 退出 所 有 PHP 代码 

64 ) 

65 else /如 果 有 记录 ， 则 执行 相应 操作 

66 ( 

67 echo "<tr>"; 

68 echo "<td> 4$ </td>"; 

69 echo "<td> 作 者 </td>"; 

70 echo "<td> 价 格 </td>"; 

wA echo "<td> 类 别 </td>"; 

72 echo "«td» fft </td>"; 

73 while($rows-mysql fetch array(Sresult)) // 循 环 显 示 记 录 内 容 

74 { 

75 echo "<tr>"; 

76 echo "<td><a href=\"21-10.php?id=".$rows[id]."\\">".$rowsf'book_name']."</a></td>"; 
/显示 书 名 

77 echo "«td»".$rows['book author]."«/td»"; /显示 作者 

78 echo "«td»".$rows['book cost]."«/td»"; /显示 价格 

79 $sql2="select type name from $table type where id-'$rows[book type]"'; 

80 S$result2-mysql query($sql2); 

81 $rows2-mysql fetch array(Sresult2); 

82 echo "«td»" $rows2[0]."«/td»"; // 显 示 类 别 

83 if(strlen(Srows['book description])»100) 

84 $rows['book description']-substr($rows['description'],O, 100); 

85 echo "«td»".Srows['book description']."«/td»"; 

86 echo "</tr>"; 

87 } 

88 y 

89 echo "</table>"; 

90 /以 下 为 分 页 显示 内 容 

91 $prev_page=$page-1; 

92 $next_page=$page+1; 

93 echo " <p align=\"center\"> "; 

94 if ($page>1) 

95 { 

96 echo "<a href='$PATH_INFO?page=1> 第 一 页 </a> |" 

97 y 

98 if ($prev_page>=1) 

99 t 
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100 echo "<a href='$PATH_INFO?page=$prev_page'> 上 一 页 </a> |" 
101 ) 

102 if($next page«-$p count) 

103 { 

104 echo "<a href-'SPATH INFO?page-$next page» ^ —7i«/a» |" 
105 H 

106 if (Spage«$p count) 

107 { 

108 echo "<a href='$PATH_INFO?page=$p_count> 最 后 一 页 </a></p>"; 
109 j 

110 echo "</center>"; 

111 echo "</body>"; 

112 echo "</html>"; 

113 

114 ?> 


在 PHP 运行 环境 中 执行 该 文件 ， 执 行 结果 如 图 21.4 所 示 。 


[€] B hap//localhost21 D ~ © | B aa 


EHBL HAER £455 EHEZ EAD 
盘 看 所 有 神 类 


主 类 1 (0) 
ug (0) 
图 21.4 查看 所 有 分 类 执行 结果 
由 于 我 们 并 没有 在 数据 库 中 添加 书籍 分 类 ， 因 此 这 里 只 显示 默认 的 类 别 。 


21.5.4 ”搜索 图 书页 面 的 实现 


JA 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 21 章 \ 搜 索 图 书页 面 .wmv 

如 果 图 书 的 种 类 太 多 ,给 用 户 提供 一 个 搜索 的 平台 是 有 必要 的 。 用 户 可 以 按照 图 书 的 名 称 、 作 者 、 
出 版 社 及 所 属 类 型 等 各 项 信息 来 查找 相应 的 目标 图 书 。 如 果 找到 了 相应 的 图 书 ， 就 循环 显示 所 有 查找 
结果 ， 并 给 出 相应 的 查看 该 书 详情 的 超 链接 。 

【实例 21-9】 以 下 为 搜索 图 书页 面 实现 代码 。 


K | 实例 21-9， 搜 索 图 书页 面 


源码 路 径 : 光盘 \ 源 文件 21\21-9.php 


01 <?php 

02 echo "<html>"; 

03 echo "<head>"; 

04 echo "<title> 图 书 搜索 </title>"; 
05 echo "</head>"; 

06 echo "<body>"; 

07 require "21-3.php"; 
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08 if($ POST[search c) // 如 果 没 有 默认 参数 ， 显 示 HTML. 
09 { 

10 echo "<script language=\"javascript\">"; 

11 echo "function juge(theForm)"; 

12 echo "(*; 

13 echo "if (theForm.search c.value == \"\")"; 

14 echo "(*; 

15 echo "alert(\" 请 输入 搜索 内 容 ! Vy" 

16 echo "theForm.search c.focus();"; 

17 echo "return (false);"; 

18 echo "}"; 

19 echo "}"; 

20 echo "</script>"; 

21 echo "<center>"; 

22 echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">"; 
23 echo "<form method=\"post\" action=\"$PATH_INFO\" onsubmit=\"return juge(this)\">"; 
24 echo "<tr>"; 

25 echo "<td colspan=\"2\" align=\"center\"><font size=\"5px\"> 图 书 搜索 </font></td>"; 
26 echo "</tr>"; 

27 echo "<tr>"; 

28 echo "<td> AJR RAS: </td>"; 

29 echo "<td><input type=\"text\" name=\"search_c\"></td>"; 

30 echo "</tr>"; 

31 echo "<tr>"; 

32 echo "<td> 选 择 搜索 类 型 ，</td>"; 

33 echo "<td>"; 

34 echo "<select name-'search tV size=\"1\">"; 

35 echo "<option value-V'book name» 334 «/option»"; 

36 echo "<option value-V'book authon"» Ex «/option»"; 

37 echo "<option value=\"book_pub\"> 出 版 社 </option>"; 

38 echo "</select>"; 

39 echo"</td>"; 

40 echo "</tr>"; 

41 echo "<tr>"; 

42 echo "<td> 选 择 搜索 模式 : </td>"; 

43 echo "<td>"; 

44 echo "<input type=\"radio\" name=\"search_m\" value=\"1\" checked> 精 确 查找 "; 
45 echo "<input type=\"radio\" name=\"search_m\" value=\"2\"> 模 糊 查 找 "; 
46 echo"</td>"; 

47 echo "</tr>"; 

48 echo "<tr>"; 

49 echo "<td colspan=\"2\"><center>"; 

50 echo "<input type=\"submit\" value=\" F —#\">"; 

51 echo "<input type=\"reset\" value=\" 重 新 填 \">"; 

52 echo "</center></td>"; 

53 echo "</tr>"; 

54 echo "</form>"; 

55 echo "</table>"; 

56 echo "</center>"; 

57 echo "</body>"; 

58 echo "<html>"; 
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require "21-1.php"; // 调 用 配置 文件 
$search_c=$_POST[search_c]; /获取 表单 变量 
$search t=$ POST[search t7; 


$search m=$ POST[search m]; 
if(S$search m--"1") // 根 据 搜索 模式 的 不 同 设置 不 同 的 搜索 类 型 
1 

$sql-"select * from $table book where $search t-'$search c"; 
5 
else 
{ 

$sql="select * from $table book where $search t like '$search_c"; 
} 
S$resultzmysq! query(Ssql,Slink); /发 送 SQL 请 求 
$num=mysql_num_rows($result); /获取 结果 数 
if($num«1) /如 果 没 有 结果 ， 显 示 内 容 
{ 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">"; 

echo "<tr>"; 

echo "<td align=\"centen"><font size=\"5px\"> 图 书 搜索 </font></td>"; 

echo "</tr>"; 

echo "<tr>"; 

echo "<td align=\centen"> 对 不 起 没有 找到 你 所 要 求 的 内 容 ! </td>"; 

echo "</tr>"; 

echo "</tr>"; 

echo "<tr>"; 

echo "<td align=\Vcenten"> 点 <a href=# onclick=history.go(-1)> 这 里 </a> 返 回 </td>"; 

echo "</tr>"; 

echo "</table>"; 
) 
else /如果 有 结果 ， 循 环 显示 内 容 
{ 

echo " 共 找 到 ".$num." 条 记录 "; 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">"; 

echo "<tr>"; 

echo "<td> 书 名 </td>"; 

echo "<td> 作 者 </td>"; 

echo "<td> 价 格 </td>"; 

echo "<td> 类 别 </td>"; 

echo "<td> 简 介 </td>"; 

while($rows=mysql_fetch_array($result)) 

{ 

echo "<tr>"; 
echo "<td><a hrefz'21-10.php?id-".Srows[id']."»".$rows[book name']."«/a»«/td»"; 


// 显 示 书 名 
echo "<td>".$rows['book_author]."</td>"; // 显 示 作 者 
echo "<td>".$rows['book_cost]."</td>";， ”// 显 示 价 格 
$sql2="select type name from $table type where id-'$rows[book type]"'; 
S$result22mysql query($sql2); 
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109 $rows2-mysql fetch array(Sresult2); 

110 echo "«td»" $rows2[0]."«/td»"; // 显 示 类 别 
111 if(strlen($rows['book_description])>100) 

112 $rows| book description']-substr($rows['description'],O, 100); 
113 echo "«td»".$rows['book description']."«/td»"; 

114 echo "</tr>"; 

115 y 

116 echo "</table>"; 

117 ) 

118 echo "</center>"; 

119 echo "</body>"; 

120 echo "«/html»"; 

121 } 

122 ?» 


说 明 : 用 户 需要 对 图 书 资源 进行 搜索 时 ， 只 需要 单 击 相应 的 超 链接 就 可 以 进入 该 页 面 ， 实 现 对 图 书 的 
搜索 。 


21.5.5 ”查看 图 书 详情 页 面 的 实现 


GI 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 21 章 \ 查 看 图 书 详情 页 面 .wmv 

不 管 是 在 图 书 列表 页 面 、 按 种 类 查看 页 面 还 是 在 图 书 搜索 结果 页 面 ， 当 用 户 看 到 了 中 意 的 图 书后 ， 
都 可 以 单 击 该 图 书 的 超 链接 以 查看 该 书 的 详细 情况 。 查 看 图 书 详情 页 面包 含 该 书 的 所 有 详细 情况 。 用 
户 可 以 选择 购买 该 图 书 从 而 启动 购物 车 功能 。 

这 里 来 介绍 一 下 购物 车 的 实现 原理 。 购 物 车 可 以 采用 多 种 实现 机 制 ， 如 Cookie. Session 或 者 隐藏 
帧 等 。 这 里 将 采用 Cookie 方式 ， 即 当 用 户 单 击 “ 把 该 书 放 入 购物 车 ” 超 链接 后 ， 程 序 将 在 后 台 把 该 书 
记录 写 入 Cookie。 这 里 的 Cookie 写 入 工作 采用 JavaScript 来 实现 。 因 为 使 用 JavaScript 可 以 减少 服务 
器 的 负担 。 有 关 JavaScript 操作 Cookie 的 函数 ， 请 读者 自行 查找 相应 内 容 。 

下 面 先 给 出 要 调用 的 JS 文件 的 具体 代码 : 

function SetCookie (name, value) // 设 置 名 称 为 name, 值 为 value 的 Cookie 

(var expdate = new Date(); 

expdate.setTime(expdate.getTime() 4 30 * 60 * 1000); 

document.cookie = name-*"-"*value-*";expires-"*expdate.toGMTString()*";pathz/"; 

alert(" 添 加 商品 "+name+" 成 功 !"); 

Var 


cat=window.open("21-19.php","cat","toolbar=no,menubar=no,location=no,status=no,width=420,height=280"); 
/打开 一 个 新 窗口 来 显示 统计 的 商品 信息 ， 即 显示 “手推车 ” 


} 
function Deletecookie (name) ( /删除 名 称 为 name 的 Cookie 
var exp = new Date(); 

exp.setTime (exp.getTime() - 1); 

var cval = GetCookie (name); 

document.cookie = name + "=" + cval + "; expires-" + exp.toGMTString(); 


} 
function Clearcookie() IAR Cookie 
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var temp-document.cookie.split(";"); 
var loop3; 
var ts; 
for (loop3-0;loop3«temp.length;loop3--) 

t 

ts-temp[loop3].split(*-")[0]; 

if (ts.indexOf('mycat")!--1) 

DeleteCookie(ts ); /如 果 ts 含 mycat， 则 执行 清除 

} 


function getCookieVal (offset) { /取得 项 名 称 为 offset 的 Cookie f& 
var endstr = document.cookie.indexOf (";", offset); 
if (endstr == -1) 
endstr = document.cookie.length; 
return unescape(document.cookie.substring(offset, endstr)); 
) 


function GetCookie (name) ( /取得 名 称 为 name 的 Cookie 值 

var arg = name + "="; 

var alen = arg.length; 

var clen = document.cookie.length; 

var i= 0; 

while (i < clen) { 

var j = i + alen; 

if (document.cookie.substring(i, j) == arg) 
return getCookieVal (j); 
i = document.cookie.indexOf(" ", i) + 1; 
if (i == 0) break; 

) 

return null; 


) 


先 将 以 上 代码 保存 为 ctlcookie.js， 以 方便 程序 调用 该 JS 文件 。 
【实例 21-10】 以 下 为 查看 图 书 详情 页 面 实现 代码 。 


上] 实例 21-10: 查看 图 书 详情 页 面 
源码 路 径 ， 光盘 \ 源 文件 21\21-10.php 


01 <?php 

02 echo "<html>"; 

03 echo "<head>"; 

04 echo "<title> 查 看 图 书 详情 </title>"; 

05 echo "</head>"; 

06 echo "<body>"; 

07 require "21-3.php"; 

08 ifI$ GET[id']) // 如 果 没有 用 户 请 求 ， 显 示 信息 
09 { 

10 echo "没有 请 求 ID! <br>"; 

11 echo "点 <a href=\"21-6.php\"> 这 里 </a> 返 回首 页 !"; 
12 } 
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else 


/如 果 有 用 户 请 求 ， 执 行 操作 


echo "<script language=\"javascript\" src=\"mycat.js\">"; 
echo "</script>"; 
require "21-1.php"; 
$sql="select * from $table book where id-'$ GETR[id]"; 
S$resultzmysql query(S$sql,Slink); 
$rowszmysql fetch array($result); 
echo "<table width=\"80%\" cellpadding=\"1\" cellspacingzV 12"; 
echo "<tr>"; 
echo "<td colspan=\"2\"><center><h2> 查 看 图 书 详情 </h2></center></td>"; 
echo "</tr>"; 
echo "<tr>"; 
echo "<td width=\"30%\"> 图 书 名称 : </td>"; 
echo "«td»".$rows['book name7."«/td»"; 
echo "</tr>"; 
echo "<tr>"; 
echo "<td> 图 书 作 者 : </td>"; 
echo "<td>".$rows['book_author]."</td>"; 
echo "</tr>"; 
echo "«tr»"; 
echo "<td> 出 版 社 : </td>"; 
echo "«td»".$rows['book pub7."«/td»"; 
echo "</tr>"; 
echo "«tr»"; 
echo "<td> ff: </td>"; 
echo "<td>".$rows['book_cost']." 7t </td>"; 
echo "</tr>"; 
echo "<tr>"; 
echo "<td> 所 属 类 别 : </td>"; 
echo "«td»" $rows['book type']."«/td»"; 
echo "</tr>"; 
echo "<tr>"; 
echo "<td> 该 书 的 数量 : </td>"; 
echo "<td>".$rows['book_num1]." 本 </td>"; 
echo "</tr>"; 
echo "<tr>"; 
echo "<td> 该 书 的 简介 : </td>"; 
echo "<td>".$rows['book_description]."</td>"; 
echo "</tr>"; 
echo "<tr>"; 
echo "<td> 该 书 的 封面 扫描 图 : </td>"; 
echo "<td>"; 
if(!$rows['book_photo']) 
t 
$rows[book photo']-"images/nopic.gif"; 
H 
echo "<img srczV".$rows['book photo." "»": 
echo "</td>"; 
echo "</tr>"; 
echo "<tr>"; 
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64 echo "<td colspan=\"2\" align=\"center\"><input type=\"button\" value=\" 把 该 书 加 入 购物 车 \" 
onclick=SetCookie(\"cat".$rows["id]."\",\"1\")></td>"; 

65 echo "</tr>"; 

66 echo "</table>"; 

67 echo "</center>"; 

68 echo "</body>"; 

69 echo "</html>"; 

70 } 

yA Mr 


21.6 ”购物 车 的 实现 


该 程序 中 的 购物 车 采用 Cookie 实现 机 制 。 本 节 来 详细 介绍 如 何 实现 购物 车 ， 及 如 何 让 用 户 的 提交 
内 容 转化 为 实 实在 在 的 订单 。 


21.6.1 查看 当前 购物 车 


GI 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 21 章 \ 查 看 当前 购物 车 .wmv 

该 页 面 要 实现 的 功能 是 统计 系统 中 当前 站 点 的 Cookie 值 。 如 果 是 描述 商品 的 Cookie， 则 记录 下 该 
Cookie 值 ， 并 读 取 库 表 中 相应 商品 的 信息 显示 给 用 户 。 用 户 可 以 自由 选择 是 否 购买 已 经 加 入 购物 车 的 
商品 ， 并 且 可 以 随便 输入 购买 的 数量 。 

【实例 21-11】 以 下 为 查看 当前 购物 车 的 代码 。 


E on ”实例 21-11: 查看 当前 购物 车 
源码 路 径 ， 光盘 \ 源 文件 21\21-11.php 


01 <?php 

02 echo "<html>"; 

03 echo "<head>"; 

04 echo "<title> 查 看 购物 车 </title>"; 

05 echo "</head>"; 

06 echo "<body>"; 

07 echo "<center>"; 

08 echo "<LINK href=\"style.css\" rel=stylesheet>"; 

09 if(IS POST[mycat]) // 如 果 没有 用 户 提交 ， 显 示 内 容 
10 { 

11 require "21-1.php"; 

12 echo "<table width=\"80%\" cellpadding=\"1\" cellspacingzV 1 V2"; 

13 echo "<form method=\"post\" action=\"$PATH_INFO\">"; 

14 echo "<input type=\"hidden\" name=\"mycat\" value=\"post\">"; 

15 echo "<tr>"; 

16 echo "<td colspan=\"4\"><center><h2> 您 的 购物 车 信息 </h2></center></td>"; 
17 echo "</tr>"; 

18 echo "<tr>"; 

19 echo "<td> 选 择 </td>"; 
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echo "<td> 名 称 </td>"; 

echo "<td> 单 价 </td>"; 

echo "<td> 数 量 </td>"; 

echo "</tr>"; 
S$temp=array_keys($ COOKIE); 
$j=0; 
for($i=0;$i<count($temp); $i++) 


if(ereg("cat",Stemp[Si])) /查找 已 添加 到 购物 车 的 商品 
d 
$j++; 
$catid=ereg_replace("cat","",$temp[$i]); 
$sql="select * from $table book where id-'$catid""; 
$result=mysql_query($sql,$link); 
$rows=mysql_fetch_array($result); 
echo "<input type=\"hidden\" name=V'id[\" value=\"".$rowsf'id']."">"; 
echo "<tr>"; 
echo "<td><input type=\"checkbox\" name=\"c".$j."\"></td>"; 
echo "<td>".$rows['book_name"]."</td>"; 
echo "<td><input type=\"text\" value=\"".$rows['book_cost']."\" name=\"m[]\" readonly 


size=\"5\"></td>"; 
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echo "<td><input type=\"text\" name= \"tf\" value=\"1\" size=\"3\"></td>"; 
echo "</tr>"; 
} 

i 

echo "<tr>"; 

echo "<td colspan=\"4\"><center>"; 

echo "<input type=\"submit\" value=\" 结 账 \">"; 

echo "<input type=\"button\" value=\" 继 续 购 物 \" onclick=window.close()>"; 

echo "</center></td>"; 

echo "</tr>"; 

echo "</form>"; 

echo "</table>"; 


$id=$_POSTT'id"; 

4$m=$_POST[m1]; 

$t-$ POSTTt]; 

$time-date("Y ££ m H d A"); 

require "21-1.php"; 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">"; 

echo "<tr><td colspan=\"4\"><center> 您 选 购 了 以 下 商品 :</center></td></tr>"; 
echo "<tr>"; 

echo "<td> 书 名 </td>"; 

echo "<td> 单 价 </td>"; 

echo "<td> 数 量 </td>"; 

echo "<td> 小 计 </td>"; 

echo "</tr>"; 

$j= 
for($i=1;$i<=count($id);$i++) // 循 环 显示 所 有 商品 
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70 F 

71 $c-"c" $i; 

72 if($$c!="") 

73 ( 

74 Stemp-$Sid[Si-1]; 

T5 Stemp2=$m[$i-1]; 

76 $temp3=$t[$i-1]; 

7 $sql-"select * from $table book where id-'$temp"; 
78 $result-mysql! query($sql,Slink); 

79 $rows-mysql fetch array(Sresult); 

80 echo "<tr>"; 

81 echo "«td»".$rows['book name"."«/td»"; 

82 echo "«td»".$temp2."«/td»"; 

83 echo "«td»".$temp3."«/td»"; 

84 Sz[Sj]-SmISi-1]"St[Si-1]; 

85 S$temp4-$z[Si]; 

86 echo "«td»" Sz[Sj]."«/td»"; 

87 echo "</tr>"; 

88 $j++; 

89 $sql="insert into $table order(order user id,order book id,order book num,order - 


user name,order cost,order date) values('$ COOKIE[id]',$temp','Stemp3','$ COOKIE[user]''$temp4",'$time")"; 
90 mysql query(S$sql,$link); 


91 ) 

92 

93 for($i-0;Si«count($z);Si--*) 

94 ( 

95 $s=$s+$z[$i]; 

96 ) 

97 echo "<tr><td colspan-'4V'» «center» &it:" Ss." «/center» «/td» «/tr»"; 
98 echo "<tr><td colspan=\"4\"> 已 经 生成 订单 ,点 <input type-V' button" valuezV ix E £& s B fV 
onclickewindow.close»«/td? «/tr»"; 

99 ) 

100 ?> 


该 文件 具备 了 查看 购物 车 、 选 择 选 购 的 商品 、 提 交 购物 车 信息 等 功能 ， 是 购物 车 功能 的 主体 文件 。 
21.62 ”查看 用 户 历史 订单 


GEH 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 21 章 \ 查 看 用 户 历 史 订 单 .wmv 

用 户 在 提交 购物 车 后 ， 购 物 信息 将 生成 订单 。 所 以 应 该 使 用 户 有 权限 查看 所 有 的 历史 订单 。 该 功 
能 的 实现 也 很 简单 ， 从 订单 记录 表 里 选 取 用户 名 为 当前 登录 用 户 的 记录 显示 出 来 即 可 。 

【实例 21-12】 以 下 为 查看 用 户 历史 订单 的 代码 。 


实例 21-12: 查看 用 户 历 史 订 单 
源码 路 径 光盘 \ 源 文件 21\21-12.php 


01 <?php 
02 echo "<html>"; 
03 echo "<head>"; 
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04 
05 
06 
07 
08 
09 
10 
11 
12 
13 
14 


echo "<title> 查 看 登录 用 户 历 史 订单 </title>"; 
echo "</head>"; 

echo "<body>"; 

require "21-3.php"; 


iS 


COOKIETuser]) 


echo "你 没有 登录 ,没有 权限 执行 这 项 操作 ! <p>"; 
echo "点 <a href=\"21-5.php\"> 这 里 </a> 进 行 登录 "; 
exit(); 


require "21-1.php"; 
echo "<h2> 查 看 用 户 ".$_COOKIE[user]." 的 订单 记录 </h2>"; 
$sql="select id from $table order where order user id-'$ COOKIE[id]"; /从 列表 中 读 出 所 有 


$result=mysql_query($sql,$link) or die(mysql_error()); /发 送 查找 列表 请 求 


$num=mysql_num_rows($result); // 获 取 结 果 条 数 
$p_count=ceil($num/10); /总 页 数 
if($ GET[page]--0 && !$_GET[page]) $page=1; /当前 页 


else $page-$ GET[page]; 
echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">"; 
if($num<1) [EE SEES 
{ 
echo "<tr>"; 
echo "<td>"; 
echo "<center><h2> 暂 时 还 没有 该 用 户 的 订单 记录 </h2></center>"; // 输 出 相应 信息 
echo "</td>"; 
echo "</tr>"; 
exit(); /退出 所 有 PHP 代码 


else /如果 有 记录 ， 则 执行 相应 操作 


echo "<tr>"; 

echo "<td> 购 书 ID</td>"; 

echo "<td> 购 书 数量 </td>"; 

echo "<td> 购 书 总 额 </td>"; 

echo "<td> 订 单 状态 </td>"; 

echo "<td> 提 交 日 期 </td>"; 

echo "</tr>"; 

$s=($page-1)*10; 

S$sql="select * from S$table_order where order user id-'$ COOKIE[id] order by id limit $s,10"; 

S$result-mysql query($sql.Slink); 

while($rows-mysql fetch array(Sresult)) 

t 
echo "<tr>"; 
echo "«td»".$rows['order book id]."</td>"; 
echo "«td»".$rows['order book num'."«/td»"; 
echo "«td»".$rows['order cost']."«/td»"; 
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52 echo "<td>".$rows['order state"."«/td»"; 

53 echo "<td>".$rows['order date"]."«/td»"; 

54 echo "</tr>"; 

55 H 

56 echo "</table>"; 

57 $prev page-$page-1; 

58 $next page-$paget1; 

59 echo " «p align- center" "; 

60 if ($page>1) 

61 

62 echo "<a href='$PATH_INFO?page=1'> 第 一 页 </a> |" 

63 ) 

64 if (Sprev page»-1) 

65 

66 echo "<a href='$PATH_INFO?page=$prev_page'> 上 一 页 </a> |" 
67 

68 if ($next_page<=$p_count) 

69 { 

70 echo "<a href='$PATH_INFO?page=$next_page'> 下 一 页 </a> | "; 
71 ) 

72 if (5page«$p count) 

73 { 

74 echo "<a href='$PATH_INFO?page=$p_count'> 最 后 一 页 </a></p>"; 
75 } 

76 echo "</center>"; 

WA echo "</body>"; 

78 echo "</html>"; 

79 ) 

80 } 

imo 


说 明 : 这 里 可 以 方便 用 户 随 时 查看 当前 用 户 的 历史 订单 记录 。 


21.7 管理 功能 的 实现 


这 里 的 管理 功能 包括 两 层 含义 ， 一 层 含义 是 普通 用 户 可 以 更 改 自己 的 注册 信息 、 密 码 及 查看 购物 
车 等 ， 另 一 层 含义 是 管理 员 可 以 添加 或 者 修改 图 书 类 别 、 添 加 新 的 图 书 、 查 看 和 处 理 订 单 、 查 看 销售 

可 以 看 出 ， 不 管 对 于 普通 用 户 还 是 管理 者 ， 后 台 的 管理 功能 都 是 十 分 重要 的 。 本 节 就 来 逐个 实现 
这 些 后 台 管 理 功能 。 这 里 将 所 有 管理 操作 的 链接 都 集中 在 一 个 页 面 上 ， 即 用 户 登录 页 ， 用 户 在 登录 前 
显示 的 是 登录 界面 ， 而 在 登录 之 后 ， 则 显示 所 有 操作 的 超 链接 ， 如 图 21.5 所 示 。 

通过 这 个 界面 ， 普 通用 户 或 者 管理 员 可 以 执行 相应 的 操作 。 当 然 ， 只 有 管理 员 才 能 执行 的 操作 ， 
普通 用 户 是 看 不 到 的 。 


M aaa 
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图 21.5 管理 员 登 录 后 的 “管理 入 口 ”执行 结果 


21.7.1 ”更改 用 户 信息 


GE 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 21 章 \ 更 改 用 户 信息 .wmv 

注册 用 户 的 信息 在 注册 后 并 不 是 一 成 不 变 的 ， 用 户 可 以 自由 更 改 自 己 的 信息 ， 而 用 户 信息 的 更 改 
实质 就 是 改变 表 中 特定 项 的 记录 。 先 给 出 用 户 一 个 人 机 交互 界面 ， 要 求 用 户 输入 更 改 的 内 容 ， 然 后 转 
到 后 台 ， 对 相应 项 进行 更 改 操作 。 

【实例 21-13】 以 下 为 更 改 用 户 信息 代码 。 


01 <?php 

02 echo "«html»"; 

03 echo "<head>"; 

04 echo "<title> 修 改 注册 用 户 信息 </title>"; 

05 echo "</head>"; 

06 echo "<body>"; 

07 echo "<center>"; 

08 require "21-3.php"; 

09 if! COOKIE[user]) 

10 { 

11 echo "你 还 没有 登录 ! <p>"; 

12 echo "点 <a href=\"21-5.php\"> 这 里 </a> 进 行 登录 "; 
13 exit(); 

14 ) 

15 else 

16 

17 if(IS POST['email]) 

18 { 

19 echo "<script language- "javascript" 7"; 
20 echo "function juge(theForm)"; 
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42 
43 
44 
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56 
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60 
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echo "(*; 

echo "if (theForm.email.value == \"\")"; 

echo "f"; 

echo "alert(\" 请 输入 邮箱 ! \");"; 

echo "theForm.email.focus();"; 

echo "return (false);"; 

echo ^": 

echo "^ 

echo "function s photo(the)"; 

echo "f"; 

echo "document.img.src-'images/"*the.photo.value-*'.bmp';"; 
echo "^ 

echo "</script>"; 

require "21-1.php"; 

$sql-"select * from $table user where id-'$ COOKIE[id]"'; 
S$resultemysql query($sql.Slink); 
$rowszmysql fetch array(Sresult); 

echo "<table cellpadding=\"1\" cellspacing=\"1\" width=\"80%\">"; 


echo "<form method=\"post\" action=\"$PATH_INFO\" onsubmit=\"return juge(this)\">"; 


echo "<tr>"; 

echo "<td colspan=\"2V> 以 下 几 项 是 可 以 修改 的 : </td>"; 

echo "</tr>"; 

echo "<tr>"; 

echo "<td> 用 户 地 址 :</td>"; 

echo "<td><input type=\"text\" name=\"address\" value=\"". $rows[address]."\"></td>"; 
echo "</tr>"; 

echo "<tr>"; 

echo "<td> 用 户 邮 箱 : </td>"; 

echo "<td><input type=\"text\" name=\"email\" value=\"".$rows['email']."\"></td>"; 
echo "</tr>"; 

echo "<tr>"; 

echo "<td> 用 户 QQ: </td>"; 

echo "<td><input type=\"text\" name=\"qq\" value=\"".$rows['qq']."\"></td>"; 

echo "</tr>"; 

echo "<tr>"; 

echo "<td> 用 户 MSN: </td>"; 

echo "<td><input type=\"text\" name=\"msn\" value=\"".$rows['msn']."\"></td>"; 
echo "</tr>"; 


echo "<tr>"; 
echo "<td> 用 户 图 像 : </td>"; 
echo "<td>"; 


echo "<select name=\"photo\" size=\"1\" onchange=\"s_photo(this.form)\">"; 
for($i=1;$i<21;$i++) 
{ 
echo "<option value=".$i.">".$i."</option>";; 
} 
echo "</select>"; 
echo "<img src=\"images/".$rows['photo']."\" name=\"img\">"; 
echo "</td>"; 
echo "</tr>"; 
echo "<tr>"; 
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72 echo "<td colspan-l 2!» «center»«input type=\"submit\" value V fri 432 V »«/center </td>"; 
73 echo "</tr>"; 

74 echo "</form>"; 

75 echo "</table>"; 

76 } 

Ttf else 

78 ( 

79 $email-$ POST[email'; 

80 $address-$ POST[address]; 

81 $qq-$ POST['aq]; 

82 $msn-$ POST[msn]; 

83 $photo-$ POST[photo; 

84 require "21-1.php"; 

85 $sql-"update Stable user set email-'$email',address-'$address',qq-'$qq'msn-'$msn', 
photo-'$photo' where id-'$ COOKIE[id]"'; 

86 if(mysql query($sql.Slink)) 

87 { 

88 echo "修改 注册 信息 成 功 ， 现 在 返回 首页 "; 

89 echo "<meta http-equiv=\"refresh\" content=\"2; url=21-6.php\">"; 
90 ) 

91 else 

92 { 

93 echo "修改 注册 信息 失败 ， 现 在 返回 更 改 信息 页 "; 

94 echo "<meta http-equiv=\"refresh\" content=\"2; urlz21-11.phpV'»"; 
95 } 

96 } 

97 } 

98 ?» 


说 明 : 当 用 户 需要 对 注册 信息 进行 更 改 时 就 可 以 调用 该 页 面 。 
21.7.2 ”更 改 用 户 密 码 


GEH 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 21 章 \ 更 改 用 户 密码 .wmv 

密码 始终 是 一 个 比较 敏感 的 选项 ， 因 为 它 是 用 户 进入 系统 的 一 个 重要 的 钥匙 ， 所 以 要 把 密码 单独 
列 出 来 更 改 。 不 过 更 改 密码 的 原理 同 更 改 普通 信息 一 样 ， 都 要 对 用 户 的 输入 进行 判断 ， 如 果 符 合 条 件 
就 用 新 密码 替换 旧 密码 。 

【实例 21-14】 以 下 为 更 改 用 户 密码 的 代码 。 


K 实例 21-14: 更 改 用 户 密码 
hi 源码 路 径 : 光盘 \ 源 文件 21\21-14.php 


01 <?php 

02 echo "<html>"; 

03 echo "<head>"; 

04 echo "<title> 修 改 注册 用 户 密码 </title>"; 
05 echo "</head>"; 

06 echo "<body>"; 
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echo "<center>"; 
require "21-3.php"; 
ifi$ COOKIE[user]) 


else 


ü 


echo "你 还 没有 登录 ! <p>"; 
echo "点 <a href=\"21-5.php\"> 这 里 </a> 进 行 登录 "; 
exit(); 


if(!$_POST['password']) 


J 


echo "<script language-'javascriptV"»"; 

echo "function juge(theForm)"; 

echo "(*; 

echo "if (theForm.password.value == \"\")"; 

echo "f"; 

echo "alert(\" 请 输入 旧 密 码 ! V"; 

echo "theForm.password.focus();"; 

echo "return (false);"; 

echo "}'; 

echo "if (theForm.newpassword.value == \"\")"; 
echo "f"; 

echo "alert(\" 请 输入 新 密码 ! Vy". 

echo "theForm.newpassword.focus();"; 

echo "return (false);"; 

echo ^"; 

echo "if (theForm.newpassword.value.length <8)"; 
echo "f"; 

echo "alert(\" 密 码 要 在 8 位 以 上 ! \");"; 

echo "theForm.newpassword.focus();"; 

echo "return (false);"; 

echo ^" 

echo "if (theForm.newpassword.value != theForm.repassword.value)"; 
echo "f"; 

echo "alert(\" 重 复 输入 的 密码 不 一 致 ! \");"; 

echo "theForm.repassword.focus();"; 

echo "return (false);"; 

echo ^" 

echo ^"; 

echo "</script>"; 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">"; 


echo "<form method=\"post\" action=\"$PATH_INFO\" onsubmit=\"retur juge(this)V'"; 


echo "<tr>"; 

echo "<td colspan=\"2\"> 修 改 用户 密 码 </td>"; 

echo "</tr>"; 

echo "<tr>"; 

echo "<td> 输 入 旧 密码 : </td>"; 

echo "<td>"; 

echo "<input type-V password" name=\"password\">"; 
echo "</td>"; 
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else 


echo "</tr>"; 

echo "<tr>"; 

echo "<td> 输 入 新 密码 :</td>"; 

echo "<td>"; 

echo "<input type=\"password\" name=\"newpassword\">"; 
echo "</td>"; 

echo "</tr>"; 

echo "<tr>"; 

echo "<td> 再 输入 一 次 :</td>"; 

echo "<td>"; 

echo "<input type=\"password\" name=\"repassword\">"; 
echo "</td>"; 

echo "</tr>"; 

echo "<tr>"; 

echo "<td colspan=\"2\"><center>"; 

echo "<input type=submit value=\" 提 交 \">"; 
echo "</center></td>"; 

echo "</tr>"; 

echo "</form>"; 

echo "</table>"; 

echo "</center>"; 

echo "</body>"; 

echo "</html>"; 


require "21-1.php"; 
$password-md5($ POST[password']); 
$newpassword-md5($ POST['newpassword'); 
$id-$ COOKIE[d']; 
S$sql-"select id from Stable user where name-'$ COOKIE[user]' and password- $password"'; 
S$result-mysql query($sql,Slink); 
$nums-mysql num rows(Sresult); 
ifSnums«1) 
t 
echo "输入 的 用 户 密码 错误 ! <p>"; 
echo "请 重新 输入 ! "; 
echo "<meta http-equiv=\"refresh\" content=\"2; url=21-12.php\">"; 
} 
else 
{ 
$sql="update $table_user set password='$newpassword' where id='$id"; 
if(mysql_query($sql,$link)) 


{ 
echo "修改 用 户 密码 成 功 ， 现 在 返回 首页 "; 
echo "<meta http-equiv=\"refresh\" content=\"2; url=20-6.php\">"; 
} 
else 
t 


echo "修改 用 户 密码 失败 ， 现 在 返回 修改 密码 页 "; 
echo "<meta http-equiv=\"refresh\" content=\"2; url=20-12.php\">"; 
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109 B 
110 } 

111 } 

112 } 

113 ?> 


21.7.3 为 图 书 添 加 新 的 分 类 


EÈ 知识 点 讲解 :光盘 \ 视 频 讲 解 \ 第 21 章 \ 为 图 书 添加 新 的 分 类 .wmv 

图 书 类 别管 理 中 的 重要 一 项 就 是 添加 新 的 分 类 。 实 际 生活 中 ， 图 书 的 种 类 是 多 种 多 样 的， 管理 员 
应 该 有 权限 为 图 书 添加 分 类 及 二 级 分 类 ， 其 实质 是 为 分 类 表 添 加 新 的 记录 。 

【实例 21-15】 以 下 为 添加 新 分 类 的 代码 。 


re 实例 21-15: 添加 新 分 类 
E) 源码 路 径 光盘 \ 源 文件 21\21-15.php 


01 <?php 

02 echo "<html>"; 

03 echo "<head>"; 

04 echo "<title> 增 加 新 的 图 书 类 别 </title>"; 

05 echo "</head>"; 

06 echo "<body>"; 

07 echo "<center>"; 

08 require "21-3.php"; 

09 require "21-1.php"; 

10 $sql-"select admin from $table user where id-'$ COOKIE[id]"'; 
11 $result-mysql query($sql,Slink); 

12 $rows-mysql fetch array(S$result); 

13 if($rows[0]!=3) 

14 { 

15 echo "你 没有 权限 执行 这 项 操作 !"; 

16 exit(); 

17 ) 

18 else 

19 

20 if(IS POST['type]) 

21 { 

22 echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">"; 
23 echo "<form method=\"post\" action=\"".$_SERVER['PHP_SELF]."\">"; 
24 echo "<tr>"; 

25 echo "<td colspan=\"2\"><center><h2> 创 建 图 书 分 类 第 一 步 </h2></center></td>"; 
26 echo "</tr>"; 

27 echo "<tr>"; 

28 echo "<td> 选 择 创建 类 别 </td>"; 

29 echo "<td>"; 

30 echo "<select size=\"1\" name=\"type\">"; 

31 echo "<option value=\"1\"> 主 类 别 </option>"; 

32 echo "<option value=\"2\"> 分 类 别 </option>"; 

33 echo "</select>"; 
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echo "</td>"; 

echo "</tr>"; 

echo "<tr>"; 

echo "<td colspan=\"2\"><center><input type=submit value=\"F—#\"></td>"; 
echo "</tr>"; 

echo "</form>"; 

echo "</table>"; 

echo "</center>"; 

echo "</body>"; 

echo "</html>"; 


else if(l$_POST[type_name]) 


{ 


echo "<script language=\"javascript\">"; 

echo "function juge(theForm)"; 

echo "f"; 

echo "if (theForm.type_name.value == \"\")"; 

echo "f"; 

echo "alert(\" 请 输入 类 别名 称 ! \");"; 

echo "theForm.topic_name.focus();"; 

echo "return (false);"; 

echo "; 

echo "if (theForm.type description.value == V)": 

echo "(*; 

echo "alert(\" 请 输入 类 别 介绍 ! Vy" 

echo "theForm.topic description.focus();"; 

echo "return (false);"; 

echo "}'; 

echo ""; 

echo "«/script»"; 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">"; 
echo "<form method=\"post\" action-V".$ SERVER[PHP SELF'."" onsubmit=\"retum 


echo "<tr>"; 
echo "<td colspan=\"2\"><center><h2> 创 建 图 书 分 类 第 二 步 </h2></center></td>"; 
echo "</tr>"; 
echo "<input type=\"hidden\" name=\"type\" value=\".$_POST[type]."\">"; 
if$ POST[type]--2) 
{ 
echo "<tr>"; 
echo "<td> 选 择 分 类 别 所 属 主 类 </td>"; 
echo "<td>"; 
echo "<select size=\"1\" name=\"p_id\">"; 
$sql="select id,type_name from $table_type where p_id=0"; 
$result=mysql_query($sql,$link); 
while($rows-mysgl fetch array($result)) 
ü 
echo "<option value=\"". $rows[id"]."\">".$rows['type_name']."</option>"; 
H 
echo "</select>"; 
echo "</td>"; 
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84 echo "</tr>"; 

85 ) 

86 echo "<tr>"; 

87 echo "<td> 输 入 类 别名 称 </td>"; 

88 echo "<td>"; 

89 echo "<input type=\"text\" name=\"type_name\">"; 

90 echo "</td>"; 

91 echo "</tr>"; 

92 echo "<tr>"; 

93 echo "<td> 输 入 类 别 介绍 </td>"; 

94 echo "«td»"; 

95 echo "<input type=\"text\" name-l'type. description"; 
96 echo "</td>"; 

97 echo "</tr>"; 

98 echo "<tr>"; 

99 echo "<td colspan-V'2V'»«center»«input type=button value=\" 上 一 步 " onclick- V'history. 
go(-1)'»«input type=submit value=\" F —#\"></td>"; 

100 echo "</tr>"; 

101 echo "</form>"; 

102 echo "</table>"; 

103 echo "</center>"; 

104 echo "</body>"; 

105 echo "</html>"; 

106 ) 

107 else 

108 { 

109 $type-$ POST['type; 

110 $type name-$ POST[type name]; 

111 $type description-$ POST[type description]; 

112 if($type==2) 

113 { 

114 $p id-$ POST[p id]; 

115 } 

116 else $p_id=0; 

117 $sql="insert into $table_type(p_id,type_name,type_description)values ('$p_id','$type_ 
name','$type description')"; 

118 if(mysql_query($sql,$link)) 

119 { 

120 echo "增加 新 类 别 操作 成 功 ， 现 在 返回 首页 ! "S 
121 echo "<meta http-equiv=\"refresh\" content=\"2; url=21-6\">"; 
122 } 

123 else 

124 ( 

125 echo "增加 新 类 别 操作 失败 ， 现 在 返回 ! "S 

126 echo "<meta http-equiv=\"refresh\" content=\"2; url=21-13\">"; 
127 } 

128 } 

129 } 

130 ?> 


当 管 理 员 调用 该 文件 时 ， 执 行 结果 如 图 21.6 所 示 。 
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BAA ë 所 在 评书 2455 Bm EEAO 
创建 图 书 分 类 第 一 步 


选择 创建 类 别 三 类 别 
分 类 别 


TS 
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图 21.6 增加 新 的 类 别 第 一 步 执行 结果 
从 图 中 选取 相应 的 创建 类 别 后 单 击 “ 下 一 步 ” 按 钮 ， 执 行 结果 如 图 21.7 所 示 。 
Ee) 
Qoo — 2-O|ecm— Do 
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创建 图 书 分 类 第 二 步 
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图 21.7 增加 新 的 类 别 第 二 步 执行 结果 


在 图 21.7 中 输入 类 别名 称 及 类 别 介绍 , 如 果 创 建 的 类 别 是 分 类 别 ,还 要 选择 该 分 类 别 所 属 主 类 别 。 
输入 完成 后 ， 就 可 以 完成 对 相应 类 别 的 添加 。 


21.7.4 修改 已 经 存在 的 分 类 


GE 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 21 章 \ 修 改 已 经 存在 的 分 类 .wmv 

设置 好 的 分 类 不 一 定 是 最 合适 的 ， 所 以 也 允许 管理 员 对 分 类 进行 修改 ， 如 修改 分 类 名 称 、 分 类 的 
说 明 、 二 级 分 类 所 属 的 主 分 类 等 。 这 些 通过 互动 表单 及 强大 的 MySQL 数据 库 语句 都 能 够 实现 。 

【实例 21-16】 以 下 为 修改 已 经 存在 分 类 的 代码 。 


K — E&8i21-16 修改 已 经 存在 分 类 000— 
源码 路 径 : 光盘 \ 源 文件 21\21-16.php 


01 <?php 

02 echo "<html>"; 

03 echo "<head>"; 

04 echo "<title> 修 改 现 有 的 图 书 类 别 </title>"; 
05 echo "</head>"; 

06 echo "<body>"; 

07 echo "<center>"; 

08 require "21-3.php"; 

09 require "21-1.php"; 


10 
11 
12 
13 
14 
15 
16 
17 
18 
19 
20 
21 
22 
23 
24 
25 
26 
27 
28 
29 
30 
31 
32 
33 
34 
35 
36 
37 
38 
39 
40 
41 
42 
43 
44 
45 
46 
47 
48 
49 
50 
51 
52 
53 
54 
55 
56 
57 
58 
59 
60 
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$sql="select admin from $table user where id-'$ COOKIE[id]"'; 
$resultzmysql query($sql,$link); 
$rows-mysql fetch array(S$result); 

if($rows[0]!=3) 


echo "你 没有 权限 执行 这 项 操作 ! "s 
exit(); 


else 
{ 
if(!$_POSTŢ'id']) 
{ 
echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">"; 
echo "<form method=\"post\" actionz"".$ SERVER[PHP SELF'.""»"; 
echo "<tr>"; 
echo "<td colspan=\"4\"><center><h2> 修 改 图 书 分 类 第 一 步 </h2></center></td>"; 
echo "</tr>"; 
echo "<tr>"; 
echo "<td> 选 择 图 书 分 类 </td>"; 
echo "<td> 分 类 类 型 </td>"; 
echo "<td> 图 书 分 类 名 称 </td>"; 
echo "<td> 该 类 别 简介 </td>"; 
echo "</tr>"; 
$sql="select id,p_id,type_name,type_description from $table type"; 
$resultemysql query($sql,Slink); 
while($rows-mysql fetch array(S$result)) 


t 
echo "<tr>"; 
echo "<td><input type=\"radio\" name=\"id\" valuez V". $rows['id']."" » «/td»"; 
echo "«td»"; 
if(Srows[p id']--0) 
echo "E 43€"; 
} 
else 
{ 
echo " 子 分 类 "; 
} 
echo "</td>"; 
echo "«td»".$rows['type name']."«/td»"; 
echo "«td»".$rows[type description]."«/td»"; 
echo "</tr>"; 
} 
echo "<tr>"; 
echo "<td colspan=\"4\"><center><input type=submit value=\"F—#\"></td>"; 
echo "</tr>"; 
echo "</form>"; 
echo "</table>"; 
echo "</center>"; 
echo "</body>"; 


echo "</html>"; 
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61 
62 
63 
64 
65 
66 
67 
68 
69 
70 
71 
72 
73 
74 
75 
76 
Za 
78 
79 
80 
81 
82 
juge(this)\">"; 
83 
84 
85 
86 
87 
88 
89 
90 
91 
92 
93 
94 
95 
96 
97 
98 
99 
100 
101 
102 
103 
104 
105 
106 


} 


else if(!$_POST['type_name]) 


{ 


echo "<script language=\"javascript\">"; 

echo "function juge(theForm)"; 

echo "f"; 

echo "if (theForm.type name.value == \"\")"; 

echo "f"; 

echo "alert(\" 请 输入 类 别名 称 ! \");"; 

echo "theForm.type name-focus();"; 

echo "return (false);"; 

echo "^; 

echo "if (theForm.type description.value == V'Y""; 

echo "f"; 

echo "alert(\" 请 输入 类 别 介 绍 ! V". 

echo "theForm.type_description.focus();"; 

echo "return (false);"; 

echo "}"; 

echo "J"; 

echo "</script>"; 

echo "«table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">"; 
echo "<form method=\"post\" actionz".$ SERVER[PHP SELF]."" onsubmit-'return 


echo "<tr>"; 
echo "<td colspan=\"2\"><center><h2> 修 改 图 书 分 类 第 二 步 </h2></center></td>"; 
echo "</tr>"; 
echo "<input type=\"hidden\" name=\"id\" value2".$. POST['id']."»"; 
$sql="select * from $table type where id-'$ POST[id]": 
$resultemysql query($sql,Slink); 
$rows-mysql fetch array(Sresult); 
if(Srows[p id']I-0) 
{ 
echo "<tr>"; 
echo "<td> 选 择 子 类 别 所 属 主 类 </td>"; 
echo "<td>"; 
echo "<select size=\"1\" name=\"p_id\">"; 
$sql2="select id,type_name from $table type where p_id=0"; 
S$result2-mysql query($sql2.Slink); 
while($rows2-mysql fetch array($result2)) 
£ 
echo "<option value=\"".$rows2f['id']; 
if(Srows2[id']--$rows[p id']) echo " checked "; 
echo ""'2".$rows2['type name7."«/option»"; 
} 
echo "</select>"; 
echo "</td>"; 
echo "</tr>"; 
} 
echo "<tr>"; 
echo "<td> 输 入 类 别名 称 </td>"; 
echo "<td>"; 
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111 echo "<input type=\"text\" name-l'type name" value=\"".$rows['type_name']."\">"; 
112 echo "</td>"; 

113 echo "</tr>"; 

114 echo "<tr>"; 

115 echo "<td> 输 入 类 别 介绍 </td>"; 

116 echo "<td>"; 

117 echo "<input type=\"text\" name=\"type_description\" value=\"".$rows['type_description']."">"; 
118 echo "</td>"; 

119 echo "«/tr»"; 

120 echo "<tr>"; 

121 echo "<td colspan=\"2\"><center><input type=button value=\" 上 一 步 "” onclick-V'history. 
go(-1) '»«input type=submit valuez F—#\"></td>"; 

122 echo "</tr>"; 

123 echo "</form>"; 

124 echo "</table>"; 

125 echo "</center>"; 

126 echo "</body>"; 

127 echo "</html>"; 

128 ) 

129 else 

130 { 

131 $id-$ POST[id]; 

132 $type-$ POST type!; 

133 $type name-$ POST[type name]; 

134 $type description-$ POST['ype description; 

135 if($ POST[p id']) 

136 { 

137 $p id-$ POST[p id; 

138 ) 

139 else 

140 { 

141 $p id-0; 

142 ) 

143 $sql-"update Stable type set p id-'$p id'type name-'$type name'type description- 
'$type description! where id-Sid"; 

144 if(mysql query($sql,Slink)) 

145 { 

146 echo "修改 图 书 分 类 操作 成 功 ， 现 在 返回 图 书 分 类 列表 !"; 
147 echo "<meta http-equiv=\"refresh\" content=\"2; url=21-8\">"; 
148 ) 

149 else 

150 { 

151 echo "修改 图 书 分 类 操作 失败 ， 现 在 返回 ! "; 

152 echo "<meta http-equiv=\"refresh\" content=\"2; url=21-14\">"; 
153 } 

154 } 

155 ) 

156 ?> 


管理 员 调 用 该 页 面 时 ， 执 行 结果 如 图 21.8 所 示 。 
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修改 图 书 分 类 第 一 步 


选择 图 书 分 类 — 分 类 类 型 。 图 书 分 类 名 称 。 该 关 别 简介 
o J% 主 类 别 1 系统 创建 的 默认 主 类 别 
[e] 了 分 类 HŽ 系统 创建 的 默认 分 类 别 
O 主 分 类 ”儿童 读物 小 孩子 看 的 书 
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21.8 ”修改 已 有 类 别 第 一 步 执行 结果 
该 页 面 显示 了 所 有 的 图 书 类 别 ， 从 中 选中 相应 类 别 前 面 的 单 选 按钮 ， 然 后 单 击 “ 下 一 步 ” 按 钮 ， 
执行 结果 如 图 21.9 所 示 。 
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图 21.9 修改 已 有 类 别 第 二 步 执行 结果 
从 图 21.9 可 以 看 出 ， 可 以 修改 类 别名 称 及 类 别 介绍 ， 如 果 选 择 修改 的 类 别 是 子 类 别 ， 还 可 以 重新 
选择 该 子 类 别 所 属 的 主 类 别 。 按 需求 对 各 项 内 容 进行 填写 ， 单 击 “ 下 一 步 ”按钮 ， 即 可 完成 对 本 类 别 
的 修改 。 
21.7.5 “增加 新 的 图 书 


GA 知识 点 讲解 :光盘 \ 视 频 讲 解 \ 第 21 章 \ 增 加 新 的 图 书 .wmv 


图 书 的 库存 量 总 是 在 不 断 增加 的 ， 所 以 增加 新 图 书 的 功能 更 是 必 不 可 少 的 。 特 别 是 在 使 用 初期 ， 
必须 把 库存 图 书 入 库 。 这 里 说 的 “入 库 ” 并 不 是 通常 意义 上 的 放 入 仓库 ， 而 是 把 所 有 图 书 的 相关 信息 
存 入 数据 表 中 。 通 过 本 节 所 述 代 码 即 可 实现 这 样 的 功能 

【实例 21-17】 以 下 为 增加 新 图 书 的 代码 。 
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HL. M 源码 路 径 光盘 \ 源 文件 21\21-17.php 
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27 
28 
29 
30 
31 
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echo "<html>"; 

echo "<head>"; 

echo "<title> 增 加 新 的 图 书 </title>"; 
echo "</head>"; 

echo "<body>"; 


echo "<center>"; 

require "21-3.php"; 

require "21-1.php"; 

$sql-"select admin from $table user where id='$ COOKIE[id]"; 
$result=mysql_query($sql, link); 
$rows-mysql fetch array(S$result); 

if($rows[0]!73) 


echo "你 没有 权限 执行 这 项 操作 ! "5 
exit(); 


else 
{ 
if(!$_POST['book_name"]) 
{ 
$sql="select id,type_name from $table_type where p_id=0"; 
$result=mysql_query($sql,$link); 
$i-0; 
while($rowszmysql fetch array(S$result)) 
i 
$j-0; 
Stemp[Si][O]-$rows[type name7; 
Sflag[$i][O]-$rows['id]; 
$sql2-"select id,type name from $table type where p id-'$rows[id]"; 
S$result2-mysql query($sql2,Slink); 
while($rows2-mysql fetch array(S$result2)) 


{ 
AE 
Stempl[Si][$j]-$rows2['type name; 
$flag[Si][Sj]-Srows2['id']; 

} 

$i++; 


} 
echo "<script language=javascript> 
function Juge(theForm) 


{ 
if (theForm.book_name.value == \"\") 


alert(\" 请 输入 书 名 MN"); 
theForm.book name.focus(); 
return (false); 


if (theForm.book author.value == \"\") 


alert(\" 请 输入 作者 N"); 
theForm.book author.focus(); 
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53 return (false); 

54 ) 

55 if (theForm.cost.value == "") 

56 { 

57 alert(\" 请 输入 书 的 价格 \"); 

58 theForm.cost.focus(); 

59 return (false); 

60 } 

61 if (theForm.book num.value == \"\") 

62 { 

63 alert(\" 请 输入 数量 \"); 

64 theForm.book num.focus(); 

65 retum (false); 

66 ) 

67 if (theForm.book description.value == \"\") 

68 { 

69 alert(w 请 输入 内 容 简介 ); 

70 theForm.book description.focus(); 

71 return (false); 

a2 ) 

73 ) 

74 function change(( 

75 for(var iedocument.f.s type.length;i»-0;i—) document.f.s type.options[i]-null; 
76 Switch(document.f.m type.options[document.f.m type.selectedlndex].text)("; 
77 for($i=0;$i<count($temp);$i++) 

78 { 

79 echo "case "."" $temp[Si][0]."":"; 

80 for($j=1;$j<count($temp[$i]);$j++) 

81 echo "document.f.s type.options[".($j-1)."-new Option(".$temp[Si][Sj]."" ".Sflag[Si][$j].^ "false, 
false);"; 

82 echo "break;"; 

83 ) 

84 echo "J)«/script»"; 

85 echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">"; 

86 echo "<form method=\"post\" action=\".$_ SERVER[PHP SELF." name=\"A" ENCTYPE 
-i'multipart/form-dataV'2"; 

87 echo "<tr>"; 

88 echo "<td colspan=\"2\"><center><h2> 增 加 新 的 图 书 第 一 步 </h2></center></td>"; 
89 echo "</tr>"; 

90 echo "<tr>"; 

91 echo "<td> 输 入 图 书 名 称 : </td>"; 

92 echo "«td»"; 

93 echo "<input type=\"text\" name=\"book_name\">"; 

94 echo "</td>"; 

95 echo "</tr>"; 

96 echo "<tr>"; 

97 echo "<td> 输 入 图 书 作 者 : </td>"; 

98 echo "<td>"; 

99 echo "<input type=\"text\" name=\"book_authon\">"; 

100 echo "</td>"; 


101 echo "</tr>"; 


102 
103 
104 
105 
106 
107 
108 
109 
110 
111 
112 
113 
114 
115 
116 
117 
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120 
121 
122 
123 
124 
125 
126 
127 
128 
129 
130 
131 
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135 
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137 
138 
139 
140 
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142 
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144 
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echo "<tr>"; 
echo "<td> 输 入 出 版 社 : </td>"; 
echo "<td>"; 
echo "<input type=\"text\" name=\"book_pub\">"; 
echo "</td>"; 
echo "</tr>"; 
echo "<tr>"; 
echo "<td> 输 入 售 价 : </td>"; 
echo "<td>"; 
echo "<input type=\"text\" name=\"book_cost\">"; 
echo "</td>"; 
echo "</tr>"; 
echo "<tr>"; 
echo "<td> 选 择 所 属 类 别 : </td>"; 
echo "<td>"; 
echo " 主 类 别 :"; 
echo "<select size=\"1\" name=\"m type\" onchange=\"change()\">"; 
for($i=0;$i<count($temp);$i++) 
{ 
echo "<option value=".$flag[$il[0].">".$temp[$il[0]; 
} 
echo "</select><br>"; 
echo "分 类 别 : "; 
echo "<select size=\"1\" name=\"s_type\">"; 
for($i=1;$i<count($temp[0]);$i++) 
{ 
echo "<option value=".$flag[0][$i].">".$temp[O][$i]; 
} 
echo "</select>"; 
echo "</td>"; 
echo "</tr>"; 
echo "<tr>"; 
echo "<td> 输 入 该 书 的 数量 : </td>"; 
echo "«td»"; 
echo "<input type- text" name? "book num"; 
echo "</td>"; 
echo "</tr>"; 
echo "<tr>"; 
echo "<td> 输 入 该 书 的 简介 : </td>"; 
echo "«td»"; 
echo "«textarea name-V'book description" cols=\"30\" rows=\"5\"></textarea>"; 
echo "</td>"; 
echo "</tr>"; 
echo "<tr>"; 
echo "<td> 上 传 该 书 的 封面 扫描 图 : </td>"; 
echo "<td>"; 
echo "<input type=\"file\" name=\"photo\">"; 
echo "</td>"; 
echo "</tr>"; 
echo "<tr>"; 
echo "<td colspan=\"2\"><center><input type=submit value=\" 下 一 步 \*></td>"; 


NK 
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153 echo "</tr>"; 

154 echo "</form>"; 

155 echo "</table>"; 

156 echo "</center>"; 

157 echo "</body>"; 

158 echo "</html>"; 

159 l 

160 else 

161 ( 

162 $book name-$ POST[book name; 

163 $book author-$ POST[book author; 

164 $book pub-$ POST[book pub; 

165 $book cost-$ POST[book cost]; 

166 $m type-$ POST['m type'; 

167 $s type-$ POST[s type; 

168 $book num-$ POST[book num]; 

169 $book description-$ POST[book description']; 

170 if($ FILES['photo']'name']I- NULL) 

171 { 

172 $filepath-"C:/Apache/htdocs/uploads/"; 

173 $tmp name-$ FILES[photo][tmp name!; 

174 $filename-'uploads/.$ FILES['photo']'name]; 

175 if((move uploaded file($tmp name,$filename))( 

176 echo "添加 新 的 图 书 操作 失败 ， 现 在 返回 重新 输入 ! "; 
177 echo "<meta http-equiv=\"refresh\" contentzV2; urlz21-17.phpV'2"; 
178 ) 

179 ) 

180 $sql-"insert into Stable book (book name,book author,book pub,book cost,book type, 


book num,book description;book photo) values('$book name';$book author','Sbook pub'/'$book cost', '$s - 
type',$book num',$book description','$filename")"; 


181 if(mysql query($sql,Slink)) 

182 { 

183 $sql="update Stable type set type_num=type_num+1 where id-'$m type"; 
184 mysql_query ($sql, $link); 

185 $sql="update $table type set type_num=type_num+1 where id-'$s type"; 
186 mysql_query ($sql, $link); 

187 echo "添加 新 的 图 书 操作 成 功 ， 现 在 返回 查看 全 部 图 书页 !"; 

188 echo "<meta http-equiv=\"refresh\" content=\"2; url=21-7.php\">"; 

189 ) 

190 else 

191 " 

192 echo "添加 新 的 图 书 操作 失败 ， 现 在 返回 重新 输入 ! "S 

193 echo "<meta http-equiv=\"refresh\" content=\"2; urlz21-15.phpV'»"; 

194 ) 

195 ) 

196 ) 

197 ?> 


这 样 在 新 书 入 库 时 就 可 以 通过 该 文件 来 实现 了 。 其 执行 结果 如 图 21.10 所 示 。 
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上 传 该 书 的 封面 扫描 图 ， 浏览 
TE 


Aic v 


图 21.10 增加 新 的 图 书 执行 结果 
说 明 : 在 这 里 可 以 输入 图 书 的 所 有 相关 信息 ， 包 括 图 书 名 称 、 图 书 作 者 、 出 版 社 、 售 价 、 所 属 主 类 别 


和 分 类 别 、 该 书 的 数量 、 该 书 的 简介 以 及 该 书 的 封面 扫描 图 等 。 其 中 该 书 的 封面 扫描 图 一 项 需 
要 上 传 。 全 部 填写 完毕 ， 单 击 “ 下 一 步 ” 按 钮 ， 即 可 生成 记录 。 


21.7.6 ”修改 已 有 图 书信 息 


F 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 21 章 \ 修 改 已 有 图 书信 息 .wmv 

图 书 在 入 库 以 后 ， 由 于 种 种 原因 ， 需 要 对 图 书 的 信息 进行 更 改 ， 这 也 是 可 以 实现 的 。 同 更 改 用 户 注 
册 信 息 一 样 ， 先 给 出 一 个 人 机 交互 界面 ， 由 管理 员 输 入 更 改 的 内 容 ， 然 后 在 后 台 对 相应 内 容 进行 更 改 。 

【实例 21-18】 以 下 为 修改 已 有 图 书信 息 的 代码 。 


01 <?php 

02 echo "<html>"; 

03 echo "<head>"; 

04 echo "<title> 修 改 已 有 的 图 书 </title>"; 
05 echo "</head>"; 

06 echo "<body>"; 

07 echo "<center>"; 

08 require "21-3.php"; 

09 require "21-1.php"; 

10 $sql-"select admin from $table user where id-'$ COOKIE[id]"'; 
11 $result=mysql_query($sql, $link); 

12 $rows=mysql_fetch_array($result); 
13 if($rows[0]!=3) 

14 t 
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15 
16 
17 
18 
19 
20 
21 
22 
23 


echo "你 没有 权限 执行 这 项 操作 ! "s 
exit(); 


else 


echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">"; 
if(IS POST[id']) 


{ 


$sql="select id from $table book"; 


/从 列表 中 读 出 所 有 图 书记 录 


$result=mysql_query($sql,$link) or die(mysql_error()); /发 送 查 找 列 表 请 求 


$num=mysql_num_rows($result); /获取 结果 条 数 
$p count-ceil($num/10); /总 页 数 
if ($ GET['page"]--0 && !$_GET["page"]) $page=1; /| 当前 页 
else $page=$ GET['page"]; 
if($num«1) /如 果 没 有 记录 
{ 
echo "<tr>"; 
echo "<td>"; 
echo "<center><h2> 暂 时 还 没有 图 书 的 记录 </h2></center>"; ”// 输 出 相应 信息 
echo "</td>"; 
echo "</tr>"; 
exit(); /退出 所 有 PHP 代码 
) 
else /如果 有 记录 ， 则 执行 相应 操作 


$s-($page-1)*10; 
$sql-"select * from $table book order by id limit $s, 10"; 
S$resultzmysql guery($sal,$link); 
echo "<form method=\"post\" actionz".$ SERVER[PHP SELF7.""»"; 
echo "<tr>"; 
echo "<td colspan=\"5\"><center><h2> 已 有 图 书 第 一 步 : 选择 记录 </h2></center> </td>"; 
echo "</tr>"; 
echo "<tr>"; 
echo "<td> 选 择 </td>"; 
echo "<td> 书 名 </td>"; 
echo "<td> 作 者 </td>"; 
echo "<td> 价 格 </td>"; 
echo "<td> 类 别 </td>"; 
while($rows=mysql_fetch_array($result)) /循环 显示 记录 内 容 
£ 
echo "<tr>"; 
echo "<td><input type=\"radio\" name=\"id\" value=\"". $rows['id']." "» «/td»"; 
echo "<td><a hrefz'21-10.php?id-" $rows[id'].""»".$rows[book name!. "</a> 


/显示 书 名 
echo "<td>".$rows[book_author]."</td>"; /显示 作者 
echo "«td»".$rows[book cost']."«/td»"; /显示 价格 


$sql2="select type_name from $table type where id-'$rows[book type]"; 
S$result2-mysql query($sql2); 

$rows2-mysq| fetch array($result2); 

echo "«td»" $rows2[0]."«/td»"; [E 

echo "</tr>"; 
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66 echo "<tr>"; 

67 echo "<td colspan=\"5\"><center><input type=\"submiñ" value=\" 修 改选 择 项 v></center> 
«Ad»"; 

68 echo "</tr>"; 

69 echo "</form>"; 

70 ) 

71 echo "</table>"; 

72 $prev page-$page-1; 

73 $next page-$page-*1; 

74 echo " «p align2V'centen"» "; 

75 if ($page>1) 

76 í 

Jtt echo "<a href='$PATH_INFO?page=1'> 第 一 页 </a> |" 
78 ) 

79 if ($prev_page>=1) 

80 { 

81 echo "<a href='$PATH_INFO?page=$prev_page'> 上 一 页 </a> |" 
82 ) 

83 if ($next page«-$p count) 

84 { 

85 echo "<a href='$PATH_INFO?page=$next_page'> 下 一 页 </a> |" 
86 

87 if (5page«$p count) 

88 { 

89 echo "<a href='$PATH_INFO?page=$p_count> 最 后 一 页 </a></p>"; 
90 ) 

91 echo "</center>"; 

92 echo "</body>"; 

93 echo "«/html»"; 

94 ) 

95 else if(l8 POST[book name!) 

96 { 

97 $sql="select id,type_name from Stable type where p_id=0"; 
98 S$resultzmysql query($sql,Slink); 

99 $i-0; 

100 while($rows-mysql fetch array(S$result)) 

101 ( 

102 $j-0; 

103 S$temp[Si][O]-$rows[type name]; 

104 S$flag[Si][O]-Srows[ id"; 

105 $sql2="select id,type name from $table type where p id-'$rows[id]"; 
106 S$result22mysql query($sql2,Slink); 

107 while($rows2-mysq| fetch array(Sresult2)) 

108 { 

109 $j++; 

110 Stemp[Si]Sj]-$rows2[type nameT; 

111 $flag[Si][Sj]-Srows2['id]; 

112 ) 

113 $i++; 

114 ) 

115 echo "<script language- javascript» 

116 function Juge(theForm) 
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117 { 
118 if (theForm.book name.value == \"\") 

119 ( 

120 alert(\" 请 输入 书 名 WN"); 

121 theForm.book name.focus(); 

122 return (false); 

123 ) 

124 if (theForm.book author.value == \"\") 

125 { 

126 alert(\" 请 输入 作者 人 ); 

127 theForm.book_author.focus(); 

128 return (false); 

129 ) 

130 if (theForm.cost.value == \"\") 

131 ( 

132 alert(\" 请 输入 书 的 价格 N\"); 

133 theForm.cost.focus(); 

134 return (false); 

135 ) 

136 if (theForm.book num.value == \"\") 

137 { 

138 alert(\" 请 输入 数量 \"); 

139 theForm.book num.focus(); 

140 return (false); 

141 ) 

142 if (theForm.book description.value == '") 

143 { 

144 alert(V isi A P3 (8) T V"); 

145 theForm.book description.focus(); 

146 return (false); 

147 ) 

148 ) 

149 function change(( 

150 for(var iedocument.f.s type.length;i»-0;i—) document.f.s type.options[i]-null; 
151 Switch(document.f.m type.options[document.f.m type.selectedIndex].text)("; 
152 for($i-0;Si«count($temp);Si--) 

153 { 

154 echo "case "."\"". $temp[$i][0]."\":"; 

155 for($j-1;Sj«count(Stemp[Si]); Sj -*) 

156 echo "document.f.s type.options[".($j-1)."]-new Option(\"".$temp[$i][$j]."\",\"".$flag [$i] 
[Sj]. false false);"; 

157 echo "break;"; 

158 ) 

159 echo "}</script>"; 

160 S$sql-"select * from $table book where id-'$ POST[id]"; 

161 S$resultzmysql query($sql,Slink); 

162 $rowszmysql fetch array(Sresult); 

163 echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">"; 
164 echo "<form method-l'post" action=\".$_ SERVER[PHP SELF].^" name=\"f" ENCTYPE 
=\"multipart/form-data\">"; 

165 echo "<input type=\"hidden\" name=\"id\" value=\"".$_POSTŢ'id']."\">"; 
166 echo "<tr>"; 


@ 
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167 echo "<td colspan=\"2\"><center><h2> 修 改 已 有 图 书 第 二 步 : 修改 相关 信息 </h2> 
</center></td>"; 

168 echo "</tr>"; 

169 echo "<tr>"; 

170 echo "<td> 输 入 图 书 名 称 : </td>"; 

171 echo "<td>"; 

172 echo "<input type=\"text\" name=\"book_name\" value=\"". $rows[book_name']."\">"; 
173 echo "</td>"; 

174 echo "</tr>"; 

175 echo "<tr>"; 

176 echo "<td> 输 入 图 书 作 者 : </td>"; 

177 echo "«td»"; 

178 echo "<input type=\"text\" name=\"book_authon\" valuez1".$rows['book author'].""»"; 
179 echo "</td>"; 

180 echo "</tr>"; 

181 echo "<tr>"; 

182 echo "<td> 输 入 出 版 社 : </td>"; 

183 echo "«td»"; 

184 echo "<input type=\"text\" namezV'book pub)" valuezV".$rows[book pub'].""»"; 
185 echo "</td>"; 

186 echo "«/tr»"; 

187 echo "<tr>"; 

188 echo "<td> 输 入 售 价 : </td>"; 

189 echo "<td>"; 

190 echo "<input type=\"text\" name=\"book_cost\" value=\"". $rows[book_cost]."\">"; 
191 echo "</td>"; 

192 echo "</tr>"; 

193 echo "<tr>"; 

194 echo "<td> 选 择 所 属 类 别 : </td>"; 

195 echo "<td>"; 

196 echo " 主 类 别 :"; 

197 echo "<select size=\"1\" name=\"m_type\"onchange=\"change()\">"; 

198 for($i=0;$i<count($temp);$i++) 

199 { 

200 echo "<option value-" Sflag[Si][0]."»".Stemp[$i][0]; 

201 ) 

202 echo "</select><br>"; 

203 echo "分 类 别 : "; 

204 echo "<select size=\"1\" name=\"s_type\">"; 

205 for($i=1;$i<count($temp[0]);$i++) 

206 { 

207 echo "<option value=".$flag[0][$i].">".$temp[0][$i]; 

208 } 

209 echo "</select>"; 

210 echo "</td>"; 

211 echo "</tr>"; 

212 echo "<tr>"; 

213 echo "<td> 输 入 该 书 的 数量 : </td>"; 

214 echo "<td>"; 

215 echo "<input type=\"text\" name=\"book_num\" value=\"".$rows[book_num']."\">"; 
216 echo "</td>"; 

217 echo "</tr>"; 
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218 echo "<tr>"; 

219 echo "<td> 输 入 该 书 的 简介 : </td>"; 

220 echo "<td>"; 

221 echo "<textarea name=\"book description cols=\"30\" rows=\"5\">".$rows [book 
description']."«/textarea?"; 

222 echo "«/td»"; 

223 echo "</tr>"; 

224 echo "<tr>"; 

225 echo "<td> 上 传 该 书 的 封面 扫描 图 : «br» 〈 如 果 无 改变 请 留 空 )》 </td>"; 
226 echo "«td»"; 

227 echo "<input type=\"file\" name=\"photo\">"; 

228 echo "</td>"; 

229 echo "</tr>"; 

230 echo "<tr>"; 

231 echo "<td colspan=\"2\"><center><input type=submit value=\" 下 一 步 \"></td>"; 
232 echo "</tr>"; 

233 echo "</form>"; 

234 echo "</table>"; 

235 echo "</center>"; 

236 echo "</body>"; 

237 echo "</html>"; 

238 ) 

239 else 

240 { 

241 $id-$ POST[id]; 

242 $book name-$ POST[book name']; 

243 $book author-k$ POST[book author); 

244 $book pub-$ POST[book pub]; 

245 $book cost-$ POST[book cost]; 

246 $m type-$ POST['m type]; 

247 $s type-$ POST[s type]; 

248 $book num-$ POST[book num]; 

249 $book description-$ POST[book description']; 

250 if($photo) 

251 { 

252 S$filepath="uploads/"; 

253 Sfile_temp=explode(".",$photo_name); 

254 Sfilename=$filepath.date("YmdHis").".".$file_temp[1]; 
255 copy($photo, $filename); 

256 unlink($photo); 

257 $sgl-"update $table book set book name-'$book name',book author- '$book_ 


author',book pub-'$book pub',book cost-'$book cost',book type-'$s type',book num-'$book num',book de 
scription-'$book description',book photo-'$filename"; 


258 ) 

259 else 

260 { 

261 $sql-"update Stable book set book name-'$book name',book author-'$book - 


author,book pub-'$book pub'book cost-'$book cost'book type-'$s type':book num-'$book num')book de 
scription-'$book description'"; 


262 ) 
263 if(mysql query($sql.Slink)) 
264 { 
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265 
266 
267 
268 
269 
270 
271 
272 
273 
274 
275 ?» 


) 
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echo "修改 已 经 有 的 图 书 操作 成 功 ， 现 在 返回 查看 全 部 图 书页 ! "; 
echo "<meta http-equiv-V'refreshY" content=\"2; url=21-7.php\">"; 


echo "修改 已 经 有 的 图 书 失败 ， 现 在 返回 重新 输入 ! "; 
echo "<meta http-equiv=\"refresh\" content=\"2; url=21-16.php\">"; 


从 以 上 代码 可 见 ， 要 对 已 有 图 书 进行 修改 共 分 三 步 : 第 一 步 ， 选 择 想 要 修改 的 图 书 。 第 二 步 ， 填 
写 修改 内 容 。 这 两 步 都 需要 人 工 干 预 。 第 三 步 为 后 台 操作 ， 用 输入 的 内 容 来 替换 已 经 存在 的 内 容 ， 从 
而 完成 修改 操作 。 第 一 步 执行 结果 如 图 21.11 所 示 。 


(E B wpyecakowzttapm 
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Hems 
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已 有 图 书 第 一 步 : 选择 记录 
选择 书 名 wa 价格 Ex] 
kia SH 20 EL 
IE -17j 


图 21.11 修改 图 书页 面 第 一 步 执行 结果 


在 图 21.11 P, 先 选择 想 要 修改 的 图 书 。 选 中 相应 图 书 前 的 单 选 按钮 , 选择 相应 图 书 , 然后 单 击 “ 修 
改选 择 项 ”按钮 ， 开 始 对 具体 内 容 进 行 修改 ， 执 行 结 果 如 图 21.12 所 示 。 
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葵 入 图 书 名 称 : 
RAESTE: 
输入 出 版 社 
RAEM. 


选择 所 属 类 别 ， 
给 入 该 书 的 数量 : 


输入 该 世 的 简 刘 ， 
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修改 已 有 图 书 第 二 步 ， 修改 相关 信息 


EG 
[EL 


EZ EEL 
229): FEV] 


hoo 


LL 


(ERHEE 7 


Rios = 


21.12 修改 图 书页 面 第 二 步 执行 结果 
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从 图 21.12 可 以 看 出 ， 这 里 可 以 对 图 书 的 所 有 信息 进行 全 方位 的 修改 。 具 体 过 程 与 添加 图 书 类 似 。 
输入 完成 后 ， 单 击 最 下 方 的 “下 一 步 ”按钮 即 可 提交 修改 内 容 。 


21.7.7 查看、 处 理 所 有 未 处 理 订单 


多 知识 点 讲解 : 光盘 \ 视 频 讲解 \ 第 21 章 \ 查 看 、 处 理 所 有 未 处 理 订单 .wmv 

用 户 提 交 购 买 请 求 后 ， 生 成 的 订单 并 不 马上 生效 ， 需 要 管理 员 对 其 进行 审核 。 只 有 在 管理 员 对 其 
进行 处 理 后 ， 才 能 变 为 销售 记录 。 所 以 ， 管 理 员 可 以 查看 并 处 理 所 有 的 用 户 订单 。 

【实例 21-19】 以 下 为 管理 员 查 看 并 处 理 所 有 用 户 订单 的 代码 。 


TE | 3:81 21-19. 管理 员 查 看 并 处 理 所 有 用 户 订单 


01 


源码 路 径 : 光盘 \ 源 文件 21\21-19.php 


<?php 


echo "<html>"; 

echo "<head>"; 

echo "<title> 查 看 所 有 未 处 理 订单 </title>"; 
echo "</head>"; 

echo "<body>"; 

require "21-3.php"; 

require "21-1.php"; 

$sql-"select admin from $table user where id-'$ COOKIEQ[id]"'; 
$resultzmysql query($sql, link); 
$rows-mysql fetch array(Sresult); 
if($rows[0]!=3) 


echo "你 没有 权限 执行 这 项 操作 ! "; 


exit(); 
) 
else 
if(I8 POST['c]) 
{ 
echo "<script language=javascript> 
function checkall(form) 
d 
for (var i=0;i<form.elements.length;i++) 
t 
var e = form.elements[i]; 
if (e.name !- 'chkall') e.checked = form.chkall.checked; 
k 
} 
</script>"; 


echo "<h2> 查 看 用 户 所 有 未 处 理 的 订单 </h2>"; 

echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">"; 

echo "<form method=\"post\" actionz".$ SERVER[PHP SELF'."'»"; 
echo "<tr>"; 

echo "«td» 48 </td>"; 

echo "<td> 提 交 人 </td>"; 


37 
38 
39 
40 
41 
42 
43 
44 
45 
46 
47 
48 
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echo "<td> S «/td»"; 
echo "<td> 书 数量 </td>"; 
echo "<td> 订 单 总 额 </td>"; 
echo "</tr>"; 
$sql="select * from $table order where order state-'false'"; 
S$result-mysql query($sql,Slink); 
while($rows-mysql fetch array(Sresult)) 
t 
echo "<tr>"; 
echo "<td><input type=checkbox name=cl valuez".$rows['id']."» «/td»"; 
echo "«td»".$rows['order user name"."«/td»"; 
echo "<td><a href-21-10.php?id-".Srows[order book id']." target=\"_blank\">". $rows 


['order book id]."</a></td>"; 


49 echo "«td»".$rows['order book num'."«/td»"; 

50 echo "«td»".$rows['order cost']."«/td»"; 

51 echo "</tr>"; 

52 ) 

53 echo "<tr>"; 

54 echo "<td colspanzV'5" alignzV'centen"»"; 

55 echo "<input type-V'checkbox name=\"chkall\” value=\"on\" onclickzV'checkall (this. 
form)\"> 选 择 所 有 记录 "; 

56 echo "<input type=\"submit\" value=\" 提 交 所 选 记录 \">"; 

57 echo "</td>"; 

58 echo "</tr>"; 

59 echo "</form>"; 

60 echo "</table>"; 

61 } 

62 else 

63 { 

64 $c=$_POST[c'; 

65 $time-date("Y ££ m A d A"); 

66 for($i-0;Si«count($c); Si) 

67 7 

68 Stemp-$c[Si]; 

69 $sql-"update Stable order set order state-'true' where id-'$temp'""; 

70 mysql query($sql.$link); 

71 $sql2-"insert into $table sale (sale order id,sale date)values('$temp','Stime")"; 
72 mysql query($sql2,Slink); 

73 $sql3-"select order book id ,order book num from $table order where id-'$temp"; 
74 $resultzmysq! query($sql3.Slink); 

75 $rows-mysql fetch array(Sresult); 

76 $sql4-"update Stable book set book sale num-book sale num-*'$rows[1]' , where 
id-'$rows[0]"': 

77 mysql query($sql4.Slink); 

78 ) 

79 echo "处 理 订单 成 功 ,正在 转 到 销售 查看 页 "; 

80 echo "<meta http-equiv=\"refresh\" content=\"2; url=21-18.php\">"; 

81 ) 

82 ) 

83 ?> 
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XE 处 理 订单 是 管理 员 才 具有 的 权限 。 


21.7.8 查看 销售 记录 


YA 知识 点 讲解 : 光盘 \ 视 频 讲 解 \ 第 21 章 \ 销 售 记录 的 查看 .wmv 
管理 员 也 可 以 查看 所 有 的 历史 销售 记录 ， 从 而 了 解 所 有 商品 的 销售 情况 。 
【实例 21-20】 以 下 为 查看 销售 记录 的 代码 。 


ES | 实例 21-20: 查看 销售 记录 O0 
源码 路 径 : 光盘 \ 源 文件 21\21-20.php 


<?php 
echo "<html>"; 
echo "<head>"; 
echo "<title> 查 看 所 有 销售 记录 </title>"; 
echo "</head>"; 
echo "<body>"; 
require "21-3.php"; 
require "21-1.php"; 
$sql="select admin from $table user where id='$_COOKIE([id]"; 
$resultzmysql query($sql,Slink); 
$rows-mysql fetch array($result); 
if($rows[0]I73) 


echo "你 没有 权限 执行 这 项 操作 ! "s 
exit(); 


01 
02 
03 
04 
05 
06 
07 
08 
09 
10 
11 
12 
13 
14 
15 
16 
17 else 
18 ( 
19 echo "<h2> 查 看 所 有 的 销售 记录 </h2>"; 
20 echo "<table width=\"80%\" cellpadding=\"1\" cellspacing=\"1\">"; 
21 $sql="select id from $table sale"; 
22 S$result-mysql query($sql.Slink ); 
23 $numzmysql| num rows(S$result); 
24 $p. count-ceil($num/10); 
25 if($ GET[page]--0 && !$ GET['page']) $page-1; /| 当前 页 
26 else $page-$ GET[page']; 
27 if($num«1) /如果 没有 记录 
28 { 
29 echo "<tr>"; 
30 echo "<td>"; 
31 echo "<center><h2> 暂 时 还 没有 图 书 的 记录 </h2></center>"; // 输 出 相应 信息 
32 echo "</td>"; 
33 echo "</tr>"; 
34 exit(); // 退 出 所 有 PHP 代码 
35 
36 
37 
38 


else /如果 有 记录 ， 则 执行 相应 操作 


$s-($page-1)*10; 
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$sql="select * from $table sale order by id limit $s, 10"; 
S$result-mysql query($sql.Slink); 
echo "<tr>"; 
echo "<td> 销 售 ID«/td»"; 
echo "<td> 提 交 人 </td>"; 
echo "<td> 购 书 ID</td>"; 
echo "<td> 购 书 价 格 </td>"; 
echo "<td> 处 理 日 期 </td>"; 
echo "</tr>"; 
while($rows=mysql_fetch_array($result) 
1 
echo "<tr>"; 
echo "«td»" $rows[id]."«/td2"; 


$sql2-"select * from Stable order where id-'$rows[id]"'; 


$result2-mysql query($sql2,$link); 
$rows2-mysql fetch array($result2); 
echo "«td»".$rows2['order user name']."«/td»"; 
echo "«td2".$rows2[order book id'."«/td»"; 
echo "«td»".$rows2[order cost']."«/td»"; 
echo "<td>".$rows['sale date']."«/td»"; 
echo "</tr>"; 
) 
echo "</table>"; 
$prev page-$page-1; 
$next page-$page*1; 
echo "<p alignzV'centen"»"; 
if ($page>1) 
{ 
echo "<a href='$PATH_INFO?page=1'> 第 一 页 </a> | "; 
} 
if ($prev_page>=1) 
{ 


echo "<a href='$PATH_INFO?page=$prev_page'> 上 一 页 </a> |", 


) 
if ($next page«-$p count) 
t 


echo "<a href='$PATH_INFO?page=$next_page'> 下 一 页 </a> |" 


} 
if (Spage«$p count) 
t 


echo "<a href='$PATH_INFO?page=$p_count> 最 后 一 页 </a></p>"; 


} 

echo "</center>"; 
echo "</body>"; 
echo "</html>"; 
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21.7.9 当前 登录 用 户 退 出 页 面 


FH 知识 点 讲解 :光盘 \ 视 频 讲解 \ 第 21 章 \ 当 前 登录 用 户 退 出 页 面 .wmv 

登录 用 户 可 以 退出 系统 ， 其 实现 方式 很 简单 ， 就 是 清空 当前 用 户 注册 的 Cookie 值 ， 并 清空 所 有 的 
购买 商品 记录 。 

【实例 21-21】 以 下 为 用 户 退 出 登录 的 代码 。 


re 实例 21-21: 用 户 退 出 登录 
源码 路 径 光盘 \ 源 文件 21\21-21.php 


01 <?php 

02 S$temp=array_keys($ COOKIE); 

03 for($i=0;$i<count($temp);$i++) /遍历 Cookie 数组 
04 

05 setcookie($temp[Si],"); IIS Cookie 记录 
06 ) 

07 echo "<html>"; 

08 echo "<head>"; 

09 echo "<title> 退 出 登录 成 功 </title>"; 

10 echo "<meta http-equiv=\"refresh\" content=\"2; url=21-6.php\">"; 

11 echo "</head>"; 

12 echo "<body>"; 

13 require "21-3.php"; 

14 echo "退出 登录 成 功 ， 现 在 转 到 首页 "; 

15 echo "</body>"; 

16 echo "</html>"; 

a £2 


说 明 : 当 用 户 需要 退出 系统 时 ， 调 用 该 页 面 ， 即 可 清空 所 有 通过 该 系统 注册 的 Cookie， 从 而 完成 退出 
动作 。 
以 上 全 部 页 面 创 建 完成 ， 该 系统 的 创建 过 程 告 一 段落 。 


21.8 A € 小结 


本 章 介绍 了 如 何 使 用 PHP 和 MySQL 数据 库 来 构建 一 个 简单 的 网 上 商城 全 站 系统 ， 详 细 地 介绍 了 
一 个 网 上 商城 所 应 具备 的 基本 功能 及 如 何 用 PHP 来 实现 这 些 功能 。 通 过 本 章 的 学 习 ,读者 对 如 何 用 PHP 
构建 网 上 商城 会 有 一 个 深刻 的 认识 。 本 章 所 创建 的 网 上 商城 功能 有 限 ， 学 完 本 书 的 读者 完全 有 能 力 来 
进一步 丰富 它 的 功能 。 


e. 


“网 站 开发 非常 之 旅 ” 系 列 全 新 推荐 书目 


网 站 建设 作为 一 项 综合 性 的 技能 , 对 许多 计算 机 技术 及 其 各 项 技术 之 间 的 关联 都 有 着 很 高 的 要 求 ， 
而 诸多 方面 的 知识 也 往往 会 使 得 许多 初学 者 感到 十 分 困惑 ， 为 此 ， 我 们 推出 了 “网 站 开发 非常 之 旅 ” 
系列 ， 自 出 版 以 来 ， 因 具有 系统 、 专 业 、 实 用 性 强 等 特点 而 深 受 广大 读者 的 喜爱 。 本 系列 为 广大 读者 
学 习 网 站 开发 技术 提供 了 一 个 完整 的 解决 方案 ， 集 技术 和 应 用 于 一 体 ， 将 网 络 编程 技术 难度 与 热点 一 
网 打 尽 ， 可 全 面 提升 您 的 网 络 应 用 开发 水 平 。 以 下 是 本 系列 最 新 书目 ， 欢 迎 选 购 ! 


ISBN 5 名 
9787302345725 | ASP.NET 项 目 开 发 详解 


9787302345732 |CSS+DIV 网 页 布局 技术 详解 


9787302344865 | Linux 服务 器 配置 与 管理 


9787302344858 iOS 移动 网 站 开发 详解 


9787302344308 |Android 移动 网 站 开发 详解 


9787302344339 | Dreamweaver CS6 网 页 设计 与 制作 详解 


9787302344100 | Java Web 开发 技术 详解 


9787302343202 | HTML4CSS 网 页 设计 详解 


9787302343189 |PHP 网 络 编程 技术 详解 


9787302342540 |ASP.NET 网 络 编程 技术 详解 


出 版 社 网 址 : www.tup.com.cn 
技术 支持 : zhuyingbiao@126.com 


